Documentation ¶
Overview ¶
Package pendingheap provides an implementation of a peer list that sends traffic to the peer with the fewest pending requests, but degenerates to round robin when all peers have equal pending requests, using a heap.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Spec ¶
func Spec() yarpcconfig.PeerListSpec
Spec returns a configuration specification for the pending heap peer list implementation, making it possible to select the least recently chosen peer with transports that use outbound peer list configuration (like HTTP).
cfg := yarpcconfig.New() cfg.MustRegisterPeerList(pendingheap.Spec())
This enables the pending heap peer list:
outbounds: otherservice: unary: http: url: https://host:port/rpc fewest-pending-requests: peers: - 127.0.0.1:8080 - 127.0.0.1:8081
Types ¶
type Configuration ¶ added in v1.31.0
type Configuration struct {
Capacity *int `config:"capacity"`
}
Configuration descripes how to build a fewest pending heap peer list.
type List ¶
type List struct {
*peerlist.List
}
List is a PeerList which rotates which peers are to be selected in a circle
type ListOption ¶
type ListOption func(*listConfig)
ListOption customizes the behavior of a pending requests peer heap.
func Capacity ¶
func Capacity(capacity int) ListOption
Capacity specifies the default capacity of the underlying data structures for this list.
Defaults to 10.
func Seed ¶ added in v1.36.0
func Seed(seed int64) ListOption
Seed specifies the random seed to use for shuffling peers.
Defaults to time in nanoseconds.