queue

package
v0.0.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 14, 2023 License: MIT Imports: 9 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	// Size of incoming requests buffer
	InBufSize = 1

	// Size of packed threads buffer
	OutBufSize = 1
)

Functions

func NewFFQueue

func NewFFQueue(
	ctx context.Context,
	pollInterval time.Duration,
	spawnDeadline time.Duration,
) *ffQueue

Fair FIFO-queue with isolated per-peer processing and adaptive invocation rate. Queue is polled with specified frequency and every scheduled call expected to be spawned until its deadline. At every moment only one call for the peer/thread pair exists in the queue. Scheduled operations could be replaced with a new ones based on the priority value (new higher-priority call replaces waiting one).

func NewThreadPacker

func NewThreadPacker(ctx context.Context, maxPackSize int, timeout time.Duration) *threadPacker

Packer accumulates peer-related thread requests and packs it into the limited-size containers during time-window constrained by provided timeout.

Types

type CallQueue

type CallQueue interface {
	// Make call immediately and synchronously return its result.
	Call(p peer.ID, t thread.ID, c PeerCall) error

	// Schedule call to be invoked later.
	Schedule(p peer.ID, t thread.ID, priority int, c PeerCall) bool
}

type PeerCall

type PeerCall func(context.Context, peer.ID, thread.ID) error

type ThreadPack

type ThreadPack struct {
	Peer    peer.ID
	Threads []thread.ID
}

type ThreadPacker

type ThreadPacker interface {
	// Add thread to peer's queue
	Add(pid peer.ID, tid thread.ID)

	// Start packing incoming thread requests
	Run() <-chan ThreadPack
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL