2020-07-26 17:09:05 +08:00
|
|
|
package discov
|
|
|
|
|
|
|
|
import (
|
2020-08-08 16:40:10 +08:00
|
|
|
"github.com/tal-tech/go-zero/core/discov/internal"
|
2020-08-14 15:08:06 +08:00
|
|
|
"github.com/tal-tech/go-zero/core/logx"
|
2020-07-26 17:09:05 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
|
|
|
Facade struct {
|
|
|
|
endpoints []string
|
|
|
|
registry *internal.Registry
|
|
|
|
}
|
|
|
|
|
|
|
|
FacadeListener interface {
|
|
|
|
OnAdd(key, val string)
|
|
|
|
OnDelete(key string)
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
func NewFacade(endpoints []string) Facade {
|
|
|
|
return Facade{
|
|
|
|
endpoints: endpoints,
|
|
|
|
registry: internal.GetRegistry(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f Facade) Client() internal.EtcdClient {
|
|
|
|
conn, err := f.registry.GetConn(f.endpoints)
|
2020-08-14 15:08:06 +08:00
|
|
|
logx.Must(err)
|
2020-07-26 17:09:05 +08:00
|
|
|
return conn
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f Facade) Monitor(key string, l FacadeListener) {
|
|
|
|
f.registry.Monitor(f.endpoints, key, listenerAdapter{l})
|
|
|
|
}
|
|
|
|
|
|
|
|
type listenerAdapter struct {
|
|
|
|
l FacadeListener
|
|
|
|
}
|
|
|
|
|
|
|
|
func (la listenerAdapter) OnAdd(kv internal.KV) {
|
|
|
|
la.l.OnAdd(kv.Key, kv.Val)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (la listenerAdapter) OnDelete(kv internal.KV) {
|
|
|
|
la.l.OnDelete(kv.Key)
|
|
|
|
}
|