Documentation ¶
Overview ¶
Package selector is a way to pick a list of service nodes
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( DefaultSelector = NewSelector() ErrNotFound = errors.New("not found") ErrNoneAvailable = errors.New("none available") )
var (
DefaultTTL = time.Minute
)
Functions ¶
This section is empty.
Types ¶
type Filter ¶
Filter is used to filter a service during the selection process
func FilterEndpoint ¶
FilterEndpoint is an endpoint based Select Filter which will only return services with the endpoint specified.
func FilterLabel ¶
FilterLabel is a label based Select Filter which will only return services with the label specified.
func FilterVersion ¶
FilterVersion is a version based Select Filter which will only return services with the version specified.
type Next ¶
Next is a function that returns the next node based on the selector's strategy
func RoundRobin ¶
RoundRobin is a roundrobin strategy algorithm for node selection
type Option ¶
type Option func(*Options)
Option used to initialise the selector
func SetStrategy ¶
SetStrategy sets the default strategy for the selector
type SelectOption ¶
type SelectOption func(*SelectOptions)
SelectOption used when making a select call
func WithFilter ¶
func WithFilter(fn ...Filter) SelectOption
WithFilter adds a filter function to the list of filters used during the Select call.
type SelectOptions ¶
type Selector ¶
type Selector interface { Init(opts ...Option) error Options() Options // Select returns a function which should return the next node Select(service string, opts ...SelectOption) (Next, error) // Mark sets the success/error against a node Mark(service string, node *registry.Node, err error) // Reset returns state back to zero for a service Reset(service string) // Close renders the selector unusable Close() error // Name of the selector String() string }
Selector builds on the registry as a mechanism to pick nodes and mark their status. This allows host pools and other things to be built using various algorithms.
func NewSelector ¶
Directories ¶
Path | Synopsis |
---|---|
Package dns provides a dns SRV selector
|
Package dns provides a dns SRV selector |
registry
module
|
|
broker
Module
|
|
broker/http
Module
|
|
broker/memory
Module
|
|
client
Module
|
|
client/mock
Module
|
|
client/rpc
Module
|
|
codec
Module
|
|
codec/bytes
Module
|
|
codec/grpc
Module
|
|
codec/json
Module
|
|
codec/jsonrpc
Module
|
|
codec/proto
Module
|
|
codec/protorpc
Module
|
|
errors
Module
|
|
metadata
Module
|
|
registry/consul
Module
|
|
registry/gossip
Module
|
|
registry/gossip/proto
Module
|
|
registry/mdns
Module
|
|
selector
Module
|
|
selector/dns
Module
|
|
selector/registry
Module
|
|
selector/static
Module
|
|
server
Module
|
|
server/debug
Module
|
|
server/mock
Module
|
|
server/rpc
Module
|
|
transport
Module
|
|
transport/http
Module
|
|
transport/memory
Module
|
|
Package static provides a static resolver which returns the name/ip passed in without any change
|
Package static provides a static resolver which returns the name/ip passed in without any change |