etcd3

package module
v0.0.0-...-3e21a6f Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 27, 2024 License: Apache-2.0 Imports: 16 Imported by: 0

README

etcd

contrib/etcd is a contrib module that provides a grpc registry implementation based on etcd.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func RegisterResolver

func RegisterResolver(etcdConfig clientv3.Config)

RegisterResolver register etcdBuilder as the global grpc resolver

Types

type Driver

type Driver struct {
	// contains filtered or unexported fields
}

Driver is an etcd3 registry driver. Support reference config.

func (*Driver) CreateRegistry

func (drv *Driver) CreateRegistry(cnf *conf.Configuration) (registry.Registry, error)

CreateRegistry creates a new registry.

func (*Driver) GetRegistry

func (drv *Driver) GetRegistry(name string) (registry.Registry, error)

GetRegistry gets a registry by name.

only a reference registry can be got.see the config example

func (*Driver) ResolverBuilder

func (drv *Driver) ResolverBuilder(cnf *conf.Configuration) (resolver.Builder, error)

ResolverBuilder creates a new resolver builder.

func (*Driver) WithDialOptions

func (drv *Driver) WithDialOptions(registry.DialOptions) ([]grpc.DialOption, error)

WithDialOptions no need to implement

type Options

type Options struct {
	EtcdConfig clientv3.Config `json:"etcd" yaml:"etcd"`
	TTL        time.Duration   `json:"ttl" yaml:"ttl"`
}

type Registry

type Registry struct {
	sync.RWMutex
	// contains filtered or unexported fields
}

Registry is an etcd3 registry for service discovery.

func BuildFromConfig

func BuildFromConfig(config *Options) (*Registry, error)

func New

func New() *Registry

func (*Registry) Apply

func (r *Registry) Apply(cfg *conf.Configuration)

func (*Registry) Close

func (r *Registry) Close()

func (*Registry) GetServiceInfos

func (r *Registry) GetServiceInfos(service string) ([]*registry.ServiceInfo, error)

GetServiceInfos implements registry interface

func (*Registry) Register

func (r *Registry) Register(node *registry.ServiceInfo) error

func (*Registry) TTL

func (r *Registry) TTL() time.Duration

func (*Registry) Unregister

func (r *Registry) Unregister(node *registry.ServiceInfo) error

Unregister remove service from etcd

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL