|
@@ -6,15 +6,19 @@ import (
|
|
|
"google.golang.org/grpc/resolver"
|
|
|
)
|
|
|
|
|
|
-type discovResolver struct {
|
|
|
- scheme string
|
|
|
- etcd discov.EtcdConf
|
|
|
- cc resolver.ClientConn
|
|
|
+const discovScheme = "discov"
|
|
|
+
|
|
|
+type discovBuilder struct {
|
|
|
+ etcd discov.EtcdConf
|
|
|
}
|
|
|
|
|
|
-func (r *discovResolver) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOptions) (
|
|
|
+func (b *discovBuilder) Scheme() string {
|
|
|
+ return discovScheme
|
|
|
+}
|
|
|
+
|
|
|
+func (b *discovBuilder) Build(target resolver.Target, cc resolver.ClientConn, opts resolver.BuildOptions) (
|
|
|
resolver.Resolver, error) {
|
|
|
- sub, err := discov.NewSubscriber(r.etcd.Hosts, r.etcd.Key)
|
|
|
+ sub, err := discov.NewSubscriber(b.etcd.Hosts, b.etcd.Key)
|
|
|
if err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
@@ -27,27 +31,28 @@ func (r *discovResolver) Build(target resolver.Target, cc resolver.ClientConn, o
|
|
|
Addr: val,
|
|
|
})
|
|
|
}
|
|
|
- r.cc.UpdateState(resolver.State{
|
|
|
+ cc.UpdateState(resolver.State{
|
|
|
Addresses: addrs,
|
|
|
})
|
|
|
})
|
|
|
|
|
|
- return r, nil
|
|
|
+ return &discovResolver{
|
|
|
+ cc: cc,
|
|
|
+ }, nil
|
|
|
}
|
|
|
|
|
|
-func (r *discovResolver) Close() {
|
|
|
+type discovResolver struct {
|
|
|
+ cc resolver.ClientConn
|
|
|
}
|
|
|
|
|
|
-func (r *discovResolver) ResolveNow(options resolver.ResolveNowOptions) {
|
|
|
+func (r *discovResolver) Close() {
|
|
|
}
|
|
|
|
|
|
-func (r *discovResolver) Scheme() string {
|
|
|
- return r.scheme
|
|
|
+func (r *discovResolver) ResolveNow(options resolver.ResolveNowOptions) {
|
|
|
}
|
|
|
|
|
|
-func RegisterResolver(scheme string, etcd discov.EtcdConf) {
|
|
|
- resolver.Register(&discovResolver{
|
|
|
- scheme: scheme,
|
|
|
- etcd: etcd,
|
|
|
+func RegisterResolver(etcd discov.EtcdConf) {
|
|
|
+ resolver.Register(&discovBuilder{
|
|
|
+ etcd: etcd,
|
|
|
})
|
|
|
}
|