Documentation ¶
Overview ¶
Package registry is an interface for service discovery
Index ¶
- Variables
- func Deregister(s *Service) error
- func Register(s *Service, opts ...RegisterOption) error
- func String() string
- type Endpoint
- type Node
- type Option
- type Options
- type RegisterOption
- type RegisterOptions
- type Registry
- type Result
- type Service
- type Value
- type WatchOption
- type WatchOptions
- type Watcher
Constants ¶
This section is empty.
Variables ¶
View Source
var ( DefaultRegistry = newConsulRegistry() // Not found error when GetService is called ErrNotFound = errors.New("not found") // Watcher stopped error when watcher is stopped ErrWatcherStopped = errors.New("watcher stopped") )
Functions ¶
func Register ¶
func Register(s *Service, opts ...RegisterOption) error
Register a service node. Additionally supply options such as TTL.
Types ¶
type RegisterOption ¶
type RegisterOption func(*RegisterOptions)
func RegisterTTL ¶
func RegisterTTL(t time.Duration) RegisterOption
type RegisterOptions ¶
type Registry ¶
type Registry interface { Init(...Option) error Options() Options Register(*Service, ...RegisterOption) error Deregister(*Service) error GetService(string) ([]*Service, error) ListServices() ([]*Service, error) Watch(...WatchOption) (Watcher, error) String() string }
The registry provides an interface for service discovery and an abstraction over varying implementations {consul, etcd, zookeeper, ...}
func NewRegistry ¶
type Result ¶
Result is returned by a call to Next on the watcher. Actions can be create, update, delete
type Service ¶
type Service struct { Name string `json:"name"` Version string `json:"version"` Metadata map[string]string `json:"metadata"` Endpoints []*Endpoint `json:"endpoints"` Nodes []*Node `json:"nodes"` }
func GetService ¶
Retrieve a service. A slice is returned since we separate Name/Version.
func ListServices ¶
List the services. Only returns service names
type WatchOption ¶ added in v0.4.0
type WatchOption func(*WatchOptions)
type WatchOptions ¶ added in v0.4.0
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
cache
module
|
|
Package consul provides a consul based registry and is the default discovery system
|
Package consul provides a consul based registry and is the default discovery system |
etcd
module
|
|
broker/memory
Module
|
|
eureka
module
|
|
mock
Module
|
|
mock/registry/mdns
Module
|
|
server/debug/proto
Module
|
|
Package Gossip provides a gossip registry based on hashicorp/memberlist
|
Package Gossip provides a gossip registry based on hashicorp/memberlist |
proto
Package gossip is a generated protocol buffer package.
|
Package gossip is a generated protocol buffer package. |
kubernetes
module
|
|
broker
Module
|
|
broker/http
Module
|
|
broker/memory
Module
|
|
client
Module
|
|
client/api
Module
|
|
client/api/registry/mdns
Module
|
|
client/api/selector/dns
Module
|
|
client/mock
Module
|
|
client/watch
Module
|
|
client/watch/registry
Module
|
|
client/watch/registry/gossip
Module
|
|
cmd
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
Module
|
|
registry/consul
Module
|
|
registry/gossip
Module
|
|
registry/gossip/proto
Module
|
|
registry/mdns
Module
|
|
registry/memory
Module
|
|
selector
Module
|
|
selector/dns
Module
|
|
selector/registry
Module
|
|
selector/static
Module
|
|
server
Module
|
|
server/debug
Module
|
|
server/debug/proto
Module
|
|
server/mock
Module
|
|
server/rpc
Module
|
|
transport
Module
|
|
transport/http
Module
|
|
transport/memory
Module
|
|
Package mdns is a multicast dns registry
|
Package mdns is a multicast dns registry |
memory
module
|
|
Package mock provides a mock registry for testing
|
Package mock provides a mock registry for testing |
multi
module
|
|
registry/gossip/proto
Module
|
|
nacos
module
|
|
nats
module
|
|
codec/proto
Module
|
|
proxy
module
|
|
transport/memory
Module
|
|
zookeeper
module
|
Click to show internal directories.
Click to hide internal directories.