Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ( ErrNotFound = errors.New("not found") ErrNoneAvailable = errors.New("service none available") )
Functions ¶
Types ¶
type Config ¶
type Config struct { config.Config `field:"-"` Name string `field:"-"` // config name/path in config file PrefixName string `field:"-"` // config prefix name Logger logger.ILogger `field:"-"` // 保留:提供给扩展使用 Registry registry.IRegistry `field:"-"` Strategy Strategy `field:"-"` // Other options for implementations of the interface // can be stored in a context Context context.Context `field:"-"` }
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 ISelector ¶
type ISelector interface { Init(opts ...Option) error Config() *Config Match(endpoint string, opts ...SelectOption) (Next, error) // 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.
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(*Config)
OptionFn configures options of server.
func WithStrategy ¶
type SelectConfig ¶
type SelectOption ¶
type SelectOption func(*SelectConfig)
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.