micro/selector/selector.go

52 lines
1.5 KiB
Go
Raw Normal View History

2015-12-09 19:23:16 +00:00
/*
The Selector package provides a way to algorithmically filter and return
nodes required by the client or any other system. Selector's implemented
by Micro build on the registry but it's of optional use. One could
provide a static Selector that has a fixed pool.
*/
package selector
import (
"errors"
"github.com/micro/go-micro/registry"
)
// 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 Selector interface {
2016-01-04 23:07:56 +00:00
Init(opts ...Option) error
Options() Options
2015-12-09 19:23:16 +00:00
// 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
2015-12-19 21:56:14 +00:00
// Name of the selector
String() string
2015-12-09 19:23:16 +00:00
}
// Next is a function that returns the next node
2016-05-03 22:06:19 +01:00
// based on the selector's strategy
2015-12-09 19:23:16 +00:00
type Next func() (*registry.Node, error)
2016-04-23 20:15:01 +01:00
// Filter is used to filter a service during the selection process
type Filter func([]*registry.Service) []*registry.Service
2015-12-09 19:23:16 +00:00
2016-05-03 22:06:19 +01:00
// Strategy is a selection strategy e.g random, round robin
type Strategy func([]*registry.Service) Next
2015-12-09 19:23:16 +00:00
var (
2016-05-03 22:06:19 +01:00
DefaultSelector = newDefaultSelector()
2015-12-09 19:23:16 +00:00
ErrNotFound = errors.New("not found")
ErrNoneAvailable = errors.New("none available")
)
func NewSelector(opts ...Option) Selector {
2016-05-03 22:06:19 +01:00
return newDefaultSelector(opts...)
2015-12-09 19:23:16 +00:00
}