From 2c41907952eafdc3538ab228f7d36dab16478c96 Mon Sep 17 00:00:00 2001 From: Mulavar <978007503@qq.com> Date: Sun, 19 Mar 2023 23:54:45 +0800 Subject: [PATCH 1/4] feat(nacos): add nacos service registry&discovery --- cmd/admin/admin.go | 2 +- example/service_discovery/etcd/main.go | 5 +- example/service_discovery/nacos/main.go | 46 ++++++++ pkg/admin/config.go | 2 +- pkg/admin/service_discovery.go | 11 +- pkg/config/nacos/nacos.go | 39 +++---- pkg/config/nacos/nacos_test.go | 29 ----- pkg/mysql/server.go | 2 +- pkg/registry/base/base.go | 6 +- pkg/registry/discovery.go | 42 ++++++-- pkg/registry/etcd/discovery.go | 2 +- pkg/registry/etcd/registery.go | 3 +- pkg/registry/nacos/discovery.go | 93 ++++++++++++++++ pkg/registry/nacos/registry.go | 137 ++++++++++++++++++++++++ pkg/registry/registry.go | 19 ++-- pkg/util/config/nacos.go | 81 ++++++++++++++ pkg/util/config/nacos_test.go | 38 +++++++ 17 files changed, 471 insertions(+), 86 deletions(-) create mode 100644 example/service_discovery/nacos/main.go create mode 100644 pkg/registry/nacos/discovery.go create mode 100644 pkg/registry/nacos/registry.go create mode 100644 pkg/util/config/nacos.go create mode 100644 pkg/util/config/nacos_test.go diff --git a/cmd/admin/admin.go b/cmd/admin/admin.go index 34d7d40c..6fa205f4 100644 --- a/cmd/admin/admin.go +++ b/cmd/admin/admin.go @@ -85,7 +85,7 @@ func Run(bootstrapPath string, addr string) error { } registryConf := discovery.GetServiceRegistry(context.Background()) - serviceDiscovery, err := registry.InitDiscovery(registryConf.Name, registryConf.RootPath, "service", registryConf.Options) + serviceDiscovery, err := registry.InitDiscovery(registryConf.Name, registryConf.Options) if err != nil { log.Fatal("init service discovert failed: %v", err) return err diff --git a/example/service_discovery/etcd/main.go b/example/service_discovery/etcd/main.go index 4c6864e7..8b3674c3 100644 --- a/example/service_discovery/etcd/main.go +++ b/example/service_discovery/etcd/main.go @@ -30,11 +30,12 @@ import ( func main() { storeType := base.ETCD - basePath := "arana" options := make(map[string]interface{}) options["endpoints"] = "http://127.0.0.1:2379" + options["rootPath"] = "arana" + options["servicePath"] = "service" - etcdDiscovery, err := registry.InitDiscovery(storeType, basePath, "service", options) + etcdDiscovery, err := registry.InitDiscovery(storeType, options) if err != nil { log.Fatalf("Init %s discovery err:%v", storeType, err) return diff --git a/example/service_discovery/nacos/main.go b/example/service_discovery/nacos/main.go new file mode 100644 index 00000000..d9999a1b --- /dev/null +++ b/example/service_discovery/nacos/main.go @@ -0,0 +1,46 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package main + +import ( + "context" +) + +import ( + "github.com/arana-db/arana/pkg/config" + "github.com/arana-db/arana/pkg/registry" + "github.com/arana-db/arana/pkg/registry/base" + "github.com/arana-db/arana/pkg/util/log" +) + +func main() { + storeType := base.NACOS + options := make(map[string]interface{}) + options["endpoints"] = "127.0.0.1:8848" + options["scheme"] = "http" + options["username"] = "nacos" + options["password"] = "nacos" + + nacosDiscovery, err := registry.InitRegistry(&config.Registry{Options: options, Name: storeType}) + if err != nil { + log.Fatalf("Init %s discovery err:%v", storeType, err) + return + } + + nacosDiscovery.UnregisterAllService(context.Background()) +} diff --git a/pkg/admin/config.go b/pkg/admin/config.go index 2caca98a..c91f10c1 100644 --- a/pkg/admin/config.go +++ b/pkg/admin/config.go @@ -75,7 +75,7 @@ type ServiceInstanceDTO struct { // Version is the version of the compiled. Version string `json:"version"` // Endpoint addresses of the service instance. - Endpoints []*config.Listener + Endpoint *config.Listener } // XConfigWriter represents the mutations of configurations. diff --git a/pkg/admin/service_discovery.go b/pkg/admin/service_discovery.go index a2fdf9a2..bac35cfa 100644 --- a/pkg/admin/service_discovery.go +++ b/pkg/admin/service_discovery.go @@ -18,7 +18,6 @@ package admin import ( - "github.com/arana-db/arana/pkg/config" "github.com/arana-db/arana/pkg/registry/base" ) @@ -36,13 +35,11 @@ func (mysds *myServiceDiscovery) ListServices() []*ServiceInstanceDTO { srvDTOs = make([]*ServiceInstanceDTO, 0, len(services)) ) for _, srv := range services { - endpoints := make([]*config.Listener, len(srv.Endpoints)) - copy(endpoints, srv.Endpoints) srvDTOs = append(srvDTOs, &ServiceInstanceDTO{ - ID: srv.ID, - Name: srv.Name, - Version: srv.Version, - Endpoints: endpoints, + ID: srv.ID, + Name: srv.Name, + Version: srv.Version, + Endpoint: srv.Endpoint, }) } return srvDTOs diff --git a/pkg/config/nacos/nacos.go b/pkg/config/nacos/nacos.go index baaa89af..ecaf8f70 100644 --- a/pkg/config/nacos/nacos.go +++ b/pkg/config/nacos/nacos.go @@ -37,20 +37,7 @@ import ( import ( "github.com/arana-db/arana/pkg/config" "github.com/arana-db/arana/pkg/util/bytesconv" -) - -const ( - _defaultGroupName string = "arana" - - _namespaceKey string = "namespace" - _groupKey string = "group" - _username string = "username" - _password string = "password" - _server string = "endpoints" - _contextPath string = "contextPath" - _scheme string = "scheme" - - _pathSplit string = "::" + u_conf "github.com/arana-db/arana/pkg/util/config" ) var ( @@ -84,13 +71,13 @@ func (s *storeOperate) Init(options map[string]interface{}) error { } func (s *storeOperate) initNacosClient(options map[string]interface{}) error { - s.groupName = _defaultGroupName - if val, ok := options[_groupKey]; ok { + s.groupName = u_conf.DefaultGroupName + if val, ok := options[u_conf.GroupKey]; ok { s.groupName = val.(string) } - clientConfig := parseClientConfig(options) - serverConfigs := parseServerConfig(options) + clientConfig := u_conf.ParseNacosClientConfig(options) + serverConfigs := u_conf.ParseNacosServerConfig(options) // a more graceful way to create config client client, err := clients.NewConfigClient( @@ -110,15 +97,15 @@ func parseServerConfig(options map[string]interface{}) []constant.ServerConfig { cfgs := make([]constant.ServerConfig, 0) scheme := "http" - if val, ok := options[_scheme]; ok { + if val, ok := options[u_conf.Scheme]; ok { scheme = val.(string) } contextPath := "/nacos" - if val, ok := options[_contextPath]; ok { + if val, ok := options[u_conf.ContextPath]; ok { contextPath = val.(string) } - if servers, ok := options[_server]; ok { + if servers, ok := options[u_conf.Server]; ok { addresses := strings.Split(servers.(string), ",") for i := range addresses { addr := strings.Split(strings.TrimSpace(addresses[i]), ":") @@ -141,13 +128,13 @@ func parseServerConfig(options map[string]interface{}) []constant.ServerConfig { func parseClientConfig(options map[string]interface{}) constant.ClientConfig { cc := constant.ClientConfig{} - if val, ok := options[_namespaceKey]; ok { + if val, ok := options[u_conf.NamespaceIdKey]; ok { cc.NamespaceId = val.(string) } - if val, ok := options[_username]; ok { + if val, ok := options[u_conf.Username]; ok { cc.Username = val.(string) } - if val, ok := options[_password]; ok { + if val, ok := options[u_conf.Password]; ok { cc.Password = val.(string) } return cc @@ -272,9 +259,9 @@ func (w *nacosWatcher) run(ctx context.Context) { } func buildNacosDataId(v string) string { - return strings.ReplaceAll(v, "/", _pathSplit) + return strings.ReplaceAll(v, "/", u_conf.PathSplit) } func revertNacosDataId(v string) string { - return strings.ReplaceAll(v, _pathSplit, "/") + return strings.ReplaceAll(v, u_conf.PathSplit, "/") } diff --git a/pkg/config/nacos/nacos_test.go b/pkg/config/nacos/nacos_test.go index d21a8034..243197fd 100644 --- a/pkg/config/nacos/nacos_test.go +++ b/pkg/config/nacos/nacos_test.go @@ -239,32 +239,3 @@ func Test_storeOpertae(t *testing.T) { assert.NoError(t, err, "blank string should be success") } - -func Test_parseServerConfig(t *testing.T) { - // _namespaceKey string = "namespace" - // _groupKey string = "group" - // _username string = "username" - // _password string = "password" - // _server string = "endpoints" - // _contextPath string = "contextPath" - // _scheme string = "scheme" - - options := map[string]interface{}{ - _namespaceKey: "arana_test", - _groupKey: "arana_test", - _username: "nacos_test", - _password: "nacos_test", - _server: "127.0.0.1:8848,127.0.0.2:8848", - } - - clientConfig := parseClientConfig(options) - assert.Equal(t, options[_namespaceKey], clientConfig.NamespaceId) - assert.Equal(t, options[_username], clientConfig.Username) - assert.Equal(t, options[_password], clientConfig.Password) - - serverConfigs := parseServerConfig(options) - assert.Equal(t, 2, len(serverConfigs)) - - assert.Equal(t, "127.0.0.1", serverConfigs[0].IpAddr) - assert.Equal(t, "127.0.0.2", serverConfigs[1].IpAddr) -} diff --git a/pkg/mysql/server.go b/pkg/mysql/server.go index c2aa1cd3..15012985 100644 --- a/pkg/mysql/server.go +++ b/pkg/mysql/server.go @@ -34,7 +34,6 @@ import ( import ( _ "github.com/arana-db/parser/test_driver" - uconfig "github.com/arana-db/arana/pkg/util/config" perrors "github.com/pkg/errors" "go.uber.org/atomic" @@ -46,6 +45,7 @@ import ( "github.com/arana-db/arana/pkg/mysql/errors" "github.com/arana-db/arana/pkg/proto" "github.com/arana-db/arana/pkg/security" + uconfig "github.com/arana-db/arana/pkg/util/config" "github.com/arana-db/arana/pkg/util/log" ) diff --git a/pkg/registry/base/base.go b/pkg/registry/base/base.go index c1249390..ddafd67e 100644 --- a/pkg/registry/base/base.go +++ b/pkg/registry/base/base.go @@ -41,15 +41,15 @@ type ServiceInstance struct { // Version is the version of the compiled. Version string `json:"version"` // Endpoint addresses of the service instance. - Endpoints []*config.Listener + Endpoint *config.Listener } func (p ServiceInstance) String() string { - return fmt.Sprintf("Service instance: id:%s, name:%s, version:%s, endpoints:%s", p.ID, p.Name, p.Version, p.Endpoints) + return fmt.Sprintf("Service instance: id:%s, name:%s, version:%s, endpoints:%s", p.ID, p.Name, p.Version, p.Endpoint) } type Registry interface { - Register(ctx context.Context, name string, serviceInstance *ServiceInstance) error + Register(ctx context.Context, serviceInstance *ServiceInstance) error Unregister(ctx context.Context, name string) error UnregisterAllService(ctx context.Context) error } diff --git a/pkg/registry/discovery.go b/pkg/registry/discovery.go index f05bdfdc..8f6fb02e 100644 --- a/pkg/registry/discovery.go +++ b/pkg/registry/discovery.go @@ -19,6 +19,7 @@ package registry import ( "fmt" + "strings" ) import ( @@ -28,16 +29,27 @@ import ( import ( "github.com/arana-db/arana/pkg/registry/base" "github.com/arana-db/arana/pkg/registry/etcd" + "github.com/arana-db/arana/pkg/registry/nacos" "github.com/arana-db/arana/pkg/util/log" ) -func InitDiscovery(storeType string, basePath string, servicePath string, options map[string]interface{}) (base.Discovery, error) { +const ( + _rootPath = "rootPath" + _servicePath = "servicePath" + _endpoints = "endpoints" + + _defaultServicePath = "service" + _defaultRootPath = "arana" +) + +func InitDiscovery(storeType string, options map[string]interface{}) (base.Discovery, error) { var serviceDiscovery base.Discovery var err error switch storeType { case base.ETCD: - serviceDiscovery, err = initEtcdDiscovery(basePath, servicePath, []string{options["endpoints"].(string)}) + serviceDiscovery, err = initEtcdDiscovery(options) case base.NACOS: + initNacosV2Discovery(options) default: err = errors.Errorf("Service registry not support store:%s", storeType) } @@ -50,12 +62,30 @@ func InitDiscovery(storeType string, basePath string, servicePath string, option return serviceDiscovery, nil } -func initEtcdDiscovery(basePath string, servicePath string, storeAddrs []string) (base.Discovery, error) { +func initEtcdDiscovery(options map[string]interface{}) (base.Discovery, error) { + var ( + rootPath = _defaultRootPath + servicePath = _defaultServicePath + storeAddrs = make([]string, 0) + ) + + if r, ok := options[_rootPath]; ok { + rootPath = r.(string) + } + + if s, ok := options[_servicePath]; ok { + servicePath = s.(string) + } + + if e, ok := options[_endpoints]; ok { + storeAddrs = append(storeAddrs, strings.Split(e.(string), ",")...) + } + if len(storeAddrs) == 0 { return nil, fmt.Errorf("service discovery init etcd error because get endpoints nil :%v", storeAddrs) } - serviceDiscovery, err := etcd.NewEtcdV3Discovery(basePath, servicePath, storeAddrs, nil) + serviceDiscovery, err := etcd.NewEtcdV3Discovery(rootPath, servicePath, storeAddrs, nil) if err != nil { return nil, fmt.Errorf("service discovery init etcd error because err: :%v", err) } @@ -63,6 +93,6 @@ func initEtcdDiscovery(basePath string, servicePath string, storeAddrs []string) return serviceDiscovery, nil } -func initNacosDiscovery(basePath string, servicePath string, storeAddrs []string) (base.Discovery, error) { - return nil, nil +func initNacosV2Discovery(options map[string]interface{}) (base.Discovery, error) { + return nacos.NewNacosV2Discovery(options) } diff --git a/pkg/registry/etcd/discovery.go b/pkg/registry/etcd/discovery.go index 0179523e..ef360fd0 100644 --- a/pkg/registry/etcd/discovery.go +++ b/pkg/registry/etcd/discovery.go @@ -36,7 +36,7 @@ import ( "github.com/arana-db/arana/pkg/util/log" ) -// EtcdV3Discovery is a etcd service discovery. +// EtcdV3Discovery is an etcd service discovery. // It always returns the registered servers in etcd. type EtcdV3Discovery struct { BasePath string diff --git a/pkg/registry/etcd/registery.go b/pkg/registry/etcd/registery.go index 59f58c05..3a0b2fc2 100644 --- a/pkg/registry/etcd/registery.go +++ b/pkg/registry/etcd/registery.go @@ -109,7 +109,8 @@ func NewEtcdV3Registry(serviceAddr, path string, etcdAddrs []string, options *st return etcdRegistry, nil } -func (r *EtcdV3Registry) Register(ctx context.Context, name string, serviceInstance *base.ServiceInstance) error { +func (r *EtcdV3Registry) Register(ctx context.Context, serviceInstance *base.ServiceInstance) error { + name := serviceInstance.Name if strings.TrimSpace(name) == "" { return errors.New("Register service `name` can't be empty") } diff --git a/pkg/registry/nacos/discovery.go b/pkg/registry/nacos/discovery.go new file mode 100644 index 00000000..ea7a54da --- /dev/null +++ b/pkg/registry/nacos/discovery.go @@ -0,0 +1,93 @@ +package nacos + +import ( + "strings" +) + +import ( + "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" + "github.com/nacos-group/nacos-sdk-go/v2/common/logger" + "github.com/nacos-group/nacos-sdk-go/v2/vo" +) + +import ( + "github.com/arana-db/arana/pkg/config" + "github.com/arana-db/arana/pkg/registry/base" + u_conf "github.com/arana-db/arana/pkg/util/config" +) + +// NacosV2Discovery is a nacos service discovery. +// It always returns the registered servers in etcd. +type NacosV2Discovery struct { + client naming_client.INamingClient + + NamespaceId string + Servers []string // ip+port, like 127.0.0.1:8848 +} + +// NewNacosV2Discovery returns a new NacosV2Discovery. +func NewNacosV2Discovery(options map[string]interface{}) (base.Discovery, error) { + discovery := &NacosV2Discovery{} + if val, ok := options[u_conf.NamespaceIdKey]; ok { + discovery.NamespaceId = val.(string) + } + + if val, ok := options[u_conf.Server]; ok { + discovery.Servers = strings.Split(val.(string), u_conf.ServerSplit) + } + + client, err := u_conf.NewNacosV2NamingClient(options) + if err != nil { + return nil, err + } + return &NacosV2Discovery{client: client}, nil +} + +// GetServices returns the servers +func (nd *NacosV2Discovery) GetServices() []*base.ServiceInstance { + // TODO need to deal with cases that the service count is more than pageSize + services, err := nd.client.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: 1, PageSize: 10}) + if err != nil { + logger.Warnf("Could not get all service info from nacos "+ + "with namespace %s and servers %s because %s", nd.NamespaceId, nd.Servers, err) + return nil + } + + result := make([]*base.ServiceInstance, 0, services.Count) + for _, srv := range services.Doms { + instances, err := nd.client.SelectAllInstances(vo.SelectAllInstancesParam{ServiceName: srv}) + if err != nil { + logger.Warnf("Could not get all instance info from nacos "+ + "with namespace %s、servers %s and service %s because %s", nd.NamespaceId, nd.Servers, srv, err) + return nil + } + for _, instance := range instances { + result = append(result, &base.ServiceInstance{ + ID: instance.InstanceId, + Name: instance.ServiceName, + Version: "", + Endpoint: &config.Listener{ + ProtocolType: instance.Metadata[_protocolType], + SocketAddress: &config.SocketAddress{ + Address: instance.Ip, + Port: int(instance.Port), + }, + ServerVersion: instance.Metadata[_serverVersion], + }, + }) + } + } + + return result +} + +// WatchService returns a nil chan. +func (nd *NacosV2Discovery) WatchService() <-chan []*base.ServiceInstance { + // TODO will support later + return nil +} + +func (nd *NacosV2Discovery) Close() { + // TODO will support later + nd.client.CloseClient() +} diff --git a/pkg/registry/nacos/registry.go b/pkg/registry/nacos/registry.go new file mode 100644 index 00000000..6be941f8 --- /dev/null +++ b/pkg/registry/nacos/registry.go @@ -0,0 +1,137 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package nacos + +import ( + "context" + "strings" +) + +import ( + "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" + "github.com/nacos-group/nacos-sdk-go/v2/common/logger" + "github.com/nacos-group/nacos-sdk-go/v2/vo" +) + +import ( + "github.com/arana-db/arana/pkg/registry/base" + u_conf "github.com/arana-db/arana/pkg/util/config" +) + +const ( + _protocolType = "protocol_type" + _serverVersion = "server_version" +) + +type NacosV2Registry struct { + client naming_client.INamingClient + + NamespaceId string + Servers []string // ip+port, like 127.0.0.1:8848 +} + +func NewNacosV2Registry(options map[string]interface{}) (base.Registry, error) { + reg := &NacosV2Registry{} + if val, ok := options[u_conf.NamespaceIdKey]; ok { + reg.NamespaceId = val.(string) + } + + if val, ok := options[u_conf.Server]; ok { + reg.Servers = strings.Split(val.(string), u_conf.ServerSplit) + } + + client, err := u_conf.NewNacosV2NamingClient(options) + if err != nil { + return nil, err + } + return &NacosV2Registry{client: client}, nil +} + +func (ng *NacosV2Registry) Register(ctx context.Context, serviceInstance *base.ServiceInstance) error { + metadata := make(map[string]string) + metadata[_protocolType] = serviceInstance.Endpoint.ProtocolType + metadata[_serverVersion] = serviceInstance.Endpoint.ServerVersion + instance := vo.RegisterInstanceParam{ + Ip: serviceInstance.Endpoint.SocketAddress.Address, + Port: uint64(serviceInstance.Endpoint.SocketAddress.Port), + Weight: 10, + Enable: true, + Healthy: true, + ServiceName: serviceInstance.Name, + // TODO make GroupName and ClusterName configurable + GroupName: "DEFAULT_GROUP", + Metadata: metadata, + Ephemeral: true, + } + ok, err := ng.client.RegisterInstance(instance) + if err != nil { + return err + } + if !ok { + logger.Warnf("Register service %s failed.", serviceInstance) + } + return nil +} + +func (ng *NacosV2Registry) Unregister(ctx context.Context, name string) error { + instance, err := ng.client.SelectOneHealthyInstance(vo.SelectOneHealthInstanceParam{ServiceName: name}) + if err != nil { + return err + } + _, err = ng.client.DeregisterInstance(vo.DeregisterInstanceParam{ + Ip: instance.Ip, + Port: instance.Port, + ServiceName: instance.ServiceName, + Ephemeral: true, + }) + if err != nil { + return err + } + return nil +} + +func (ng *NacosV2Registry) UnregisterAllService(ctx context.Context) error { + // TODO need to deal with cases that the service count is more than pageSize + services, err := ng.client.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: 1, PageSize: 10}) + if err != nil { + return err + } + + for _, srv := range services.Doms { + instances, err := ng.client.SelectAllInstances(vo.SelectAllInstancesParam{ServiceName: srv}) + if err != nil { + return err + } + for _, inst := range instances { + flag, err := ng.client.DeregisterInstance(vo.DeregisterInstanceParam{ + Ip: inst.Ip, + Port: inst.Port, + Cluster: inst.ClusterName, + ServiceName: inst.ServiceName, + Ephemeral: true, + }) + if err != nil { + return err + } + if !flag { + logger.Infof("Deregister instance %s failed", inst) + } + } + } + return nil +} diff --git a/pkg/registry/registry.go b/pkg/registry/registry.go index 2d79122e..5a9b50e5 100644 --- a/pkg/registry/registry.go +++ b/pkg/registry/registry.go @@ -32,6 +32,7 @@ import ( "github.com/arana-db/arana/pkg/config" "github.com/arana-db/arana/pkg/registry/base" "github.com/arana-db/arana/pkg/registry/etcd" + "github.com/arana-db/arana/pkg/registry/nacos" "github.com/arana-db/arana/pkg/util/log" ) @@ -42,15 +43,17 @@ func DoRegistry(ctx context.Context, registryInstance base.Registry, name string if err != nil { return fmt.Errorf("service registry register error because get local host err:%v", err) } - for _, listener := range listeners { - tmpLister := *listener - if tmpLister.SocketAddress.Address == "0.0.0.0" || tmpLister.SocketAddress.Address == "127.0.0.1" { - tmpLister.SocketAddress.Address = serverAddr - } - serviceInstance.Endpoints = append(serviceInstance.Endpoints, &tmpLister) + // TODO this will be removed in the future + if len(listeners) == 0 { + return fmt.Errorf("listeners is not exist") } + tmpLister := listeners[0] + if tmpLister.SocketAddress.Address == "0.0.0.0" || tmpLister.SocketAddress.Address == "127.0.0.1" { + tmpLister.SocketAddress.Address = serverAddr + } + serviceInstance.Endpoint = tmpLister - return registryInstance.Register(ctx, name, serviceInstance) + return registryInstance.Register(ctx, serviceInstance) } func InitRegistry(registryConf *config.Registry) (base.Registry, error) { @@ -96,5 +99,5 @@ func initEtcdRegistry(registryConf *config.Registry) (base.Registry, error) { } func initNacosRegistry(registryConf *config.Registry) (base.Registry, error) { - return nil, nil + return nacos.NewNacosV2Registry(registryConf.Options) } diff --git a/pkg/util/config/nacos.go b/pkg/util/config/nacos.go new file mode 100644 index 00000000..6312dabf --- /dev/null +++ b/pkg/util/config/nacos.go @@ -0,0 +1,81 @@ +package config + +import ( + "strconv" + "strings" +) + +import ( + "github.com/nacos-group/nacos-sdk-go/v2/clients" + "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" + "github.com/nacos-group/nacos-sdk-go/v2/common/constant" +) + +const ( + DefaultGroupName string = "arana" + + NamespaceIdKey string = "namespace-id" + GroupKey string = "group" + Username string = "username" + Password string = "password" + Server string = "endpoints" + ContextPath string = "contextPath" + Scheme string = "scheme" + + PathSplit string = "::" + ServerSplit string = "," +) + +func NewNacosV2NamingClient(options map[string]interface{}) (naming_client.INamingClient, error) { + properties := make(map[string]interface{}) + properties[constant.KEY_CLIENT_CONFIG] = ParseNacosClientConfig(options) + properties[constant.KEY_SERVER_CONFIGS] = ParseNacosServerConfig(options) + return clients.CreateNamingClient(properties) +} + +func ParseNacosServerConfig(options map[string]interface{}) []constant.ServerConfig { + cfgs := make([]constant.ServerConfig, 0) + + scheme := "http" + if val, ok := options[Scheme]; ok { + scheme = val.(string) + } + contextPath := "/nacos" + if val, ok := options[ContextPath]; ok { + contextPath = val.(string) + } + + if servers, ok := options[Server]; ok { + addresses := strings.Split(servers.(string), ServerSplit) + for i := range addresses { + addr := strings.Split(strings.TrimSpace(addresses[i]), ":") + + ip := addr[0] + port, _ := strconv.ParseInt(addr[1], 10, 64) + + cfgs = append(cfgs, constant.ServerConfig{ + Scheme: scheme, + ContextPath: contextPath, + IpAddr: ip, + Port: uint64(port), + }) + } + } + + return cfgs +} + +func ParseNacosClientConfig(options map[string]interface{}) constant.ClientConfig { + cc := constant.ClientConfig{} + + if val, ok := options[NamespaceIdKey]; ok { + cc.NamespaceId = val.(string) + } + if val, ok := options[Username]; ok { + cc.Username = val.(string) + } + if val, ok := options[Password]; ok { + cc.Password = val.(string) + } + return cc +} diff --git a/pkg/util/config/nacos_test.go b/pkg/util/config/nacos_test.go new file mode 100644 index 00000000..68b581b5 --- /dev/null +++ b/pkg/util/config/nacos_test.go @@ -0,0 +1,38 @@ +package config + +import ( + "testing" +) + +import ( + "github.com/stretchr/testify/assert" +) + +func Test_parseServerConfig(t *testing.T) { + // NamespaceIdKey string = "namespace" + // GroupKey string = "group" + // Username string = "username" + // Password string = "password" + // Server string = "endpoints" + // ContextPath string = "contextPath" + // Scheme string = "scheme" + + options := map[string]interface{}{ + NamespaceIdKey: "arana_test", + GroupKey: "arana_test", + Username: "nacos_test", + Password: "nacos_test", + Server: "127.0.0.1:8848,127.0.0.2:8848", + } + + clientConfig := ParseNacosClientConfig(options) + assert.Equal(t, options[NamespaceIdKey], clientConfig.NamespaceId) + assert.Equal(t, options[Username], clientConfig.Username) + assert.Equal(t, options[Password], clientConfig.Password) + + serverConfigs := ParseNacosServerConfig(options) + assert.Equal(t, 2, len(serverConfigs)) + + assert.Equal(t, "127.0.0.1", serverConfigs[0].IpAddr) + assert.Equal(t, "127.0.0.2", serverConfigs[1].IpAddr) +} From 2ac4f57d40b16e25bfd9db76bc319acc4728a032 Mon Sep 17 00:00:00 2001 From: Mulavar <978007503@qq.com> Date: Wed, 22 Mar 2023 10:52:56 +0800 Subject: [PATCH 2/4] feat(nacos): add nacos service client --- conf/bootstrap.yaml | 4 +- pkg/registry/nacos/client.go | 109 ++++++++++++++++++++++++++++++++ pkg/registry/nacos/discovery.go | 73 ++++++--------------- pkg/registry/nacos/registry.go | 52 ++++----------- pkg/util/config/nacos.go | 3 +- 5 files changed, 144 insertions(+), 97 deletions(-) create mode 100644 pkg/registry/nacos/client.go diff --git a/conf/bootstrap.yaml b/conf/bootstrap.yaml index 2e04a44d..ace9184b 100644 --- a/conf/bootstrap.yaml +++ b/conf/bootstrap.yaml @@ -34,9 +34,9 @@ registry: # name: nacos # options: # endpoints: "127.0.0.1:8848" -# namespace: arana +# namespace-id: arana # group: arana -# contextPath: /nacos +# context-path: /nacos # scheme: http # username: nacos # password: nacos diff --git a/pkg/registry/nacos/client.go b/pkg/registry/nacos/client.go new file mode 100644 index 00000000..1de65d15 --- /dev/null +++ b/pkg/registry/nacos/client.go @@ -0,0 +1,109 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package nacos + +import ( + "strings" +) + +import ( + "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" + "github.com/nacos-group/nacos-sdk-go/v2/common/logger" + "github.com/nacos-group/nacos-sdk-go/v2/model" + "github.com/nacos-group/nacos-sdk-go/v2/vo" +) + +import ( + u_conf "github.com/arana-db/arana/pkg/util/config" +) + +const ( + _defaultPageSize = uint32(20) +) + +type NacosServiceClient struct { + naming_client.INamingClient + + pageSize uint32 + NamespaceId string + Servers []string // ip+port, like 127.0.0.1:8848 +} + +func NewNacosServiceClient(options map[string]interface{}) (*NacosServiceClient, error) { + var nsc = &NacosServiceClient{} + + if val, ok := options[u_conf.NamespaceIdKey]; ok { + nsc.NamespaceId = val.(string) + } + + if val, ok := options[u_conf.Server]; ok { + nsc.Servers = strings.Split(val.(string), u_conf.ServerSplit) + } + + if val, ok := options[u_conf.PageSizeKey]; ok { + nsc.pageSize = val.(uint32) + } else { + nsc.pageSize = _defaultPageSize + } + + client, err := u_conf.NewNacosV2NamingClient(options) + if err != nil { + return nil, err + } + nsc.INamingClient = client + + return nsc, nil +} + +func (ngsc *NacosServiceClient) SelectAllServiceInstances() []model.Instance { + var ( + result = make([]model.Instance, 0) + count int + currentCount = 0 + pageNo = uint32(1) + pageSize = ngsc.pageSize + ) + + srvs, err := ngsc.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: pageNo, PageSize: 1}) + if err != nil { + logger.Warnf("Failed to service count from nacos", err) + return nil + } + + count = int(srvs.Count) + for currentCount < count { + srvs, err = ngsc.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: pageNo, PageSize: pageSize}) + if err != nil { + logger.Warnf("Failed to get all services info from nacos: %s with pageNo:%d and pageSize:%d", err, pageNo, pageSize) + return nil + } + for _, srv := range srvs.Doms { + instances, err := ngsc.SelectAllInstances(vo.SelectAllInstancesParam{ServiceName: srv}) + if err != nil { + logger.Warnf("Failed to get all instances of service %s info from nacos: %s", srv, err) + return nil + } + logger.Infof("Successfully get all instances of service %s\n: ", srv, instances) + result = append(result, instances...) + } + pageNo++ + currentCount += len(srvs.Doms) + } + + return result +} diff --git a/pkg/registry/nacos/discovery.go b/pkg/registry/nacos/discovery.go index ea7a54da..53e554e1 100644 --- a/pkg/registry/nacos/discovery.go +++ b/pkg/registry/nacos/discovery.go @@ -1,42 +1,19 @@ package nacos -import ( - "strings" -) - -import ( - "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" - "github.com/nacos-group/nacos-sdk-go/v2/common/logger" - "github.com/nacos-group/nacos-sdk-go/v2/vo" -) - import ( "github.com/arana-db/arana/pkg/config" "github.com/arana-db/arana/pkg/registry/base" - u_conf "github.com/arana-db/arana/pkg/util/config" ) // NacosV2Discovery is a nacos service discovery. // It always returns the registered servers in etcd. type NacosV2Discovery struct { - client naming_client.INamingClient - - NamespaceId string - Servers []string // ip+port, like 127.0.0.1:8848 + client *NacosServiceClient } // NewNacosV2Discovery returns a new NacosV2Discovery. func NewNacosV2Discovery(options map[string]interface{}) (base.Discovery, error) { - discovery := &NacosV2Discovery{} - if val, ok := options[u_conf.NamespaceIdKey]; ok { - discovery.NamespaceId = val.(string) - } - - if val, ok := options[u_conf.Server]; ok { - discovery.Servers = strings.Split(val.(string), u_conf.ServerSplit) - } - - client, err := u_conf.NewNacosV2NamingClient(options) + client, err := NewNacosServiceClient(options) if err != nil { return nil, err } @@ -45,37 +22,23 @@ func NewNacosV2Discovery(options map[string]interface{}) (base.Discovery, error) // GetServices returns the servers func (nd *NacosV2Discovery) GetServices() []*base.ServiceInstance { - // TODO need to deal with cases that the service count is more than pageSize - services, err := nd.client.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: 1, PageSize: 10}) - if err != nil { - logger.Warnf("Could not get all service info from nacos "+ - "with namespace %s and servers %s because %s", nd.NamespaceId, nd.Servers, err) - return nil - } - - result := make([]*base.ServiceInstance, 0, services.Count) - for _, srv := range services.Doms { - instances, err := nd.client.SelectAllInstances(vo.SelectAllInstancesParam{ServiceName: srv}) - if err != nil { - logger.Warnf("Could not get all instance info from nacos "+ - "with namespace %s、servers %s and service %s because %s", nd.NamespaceId, nd.Servers, srv, err) - return nil - } - for _, instance := range instances { - result = append(result, &base.ServiceInstance{ - ID: instance.InstanceId, - Name: instance.ServiceName, - Version: "", - Endpoint: &config.Listener{ - ProtocolType: instance.Metadata[_protocolType], - SocketAddress: &config.SocketAddress{ - Address: instance.Ip, - Port: int(instance.Port), - }, - ServerVersion: instance.Metadata[_serverVersion], + instances := nd.client.SelectAllServiceInstances() + result := make([]*base.ServiceInstance, 0, len(instances)) + + for _, instance := range instances { + result = append(result, &base.ServiceInstance{ + ID: instance.InstanceId, + Name: instance.ServiceName, + Version: "", + Endpoint: &config.Listener{ + ProtocolType: instance.Metadata[_protocolType], + SocketAddress: &config.SocketAddress{ + Address: instance.Ip, + Port: int(instance.Port), }, - }) - } + ServerVersion: instance.Metadata[_serverVersion], + }, + }) } return result diff --git a/pkg/registry/nacos/registry.go b/pkg/registry/nacos/registry.go index 6be941f8..bad3f9c0 100644 --- a/pkg/registry/nacos/registry.go +++ b/pkg/registry/nacos/registry.go @@ -19,18 +19,15 @@ package nacos import ( "context" - "strings" ) import ( - "github.com/nacos-group/nacos-sdk-go/v2/clients/naming_client" "github.com/nacos-group/nacos-sdk-go/v2/common/logger" "github.com/nacos-group/nacos-sdk-go/v2/vo" ) import ( "github.com/arana-db/arana/pkg/registry/base" - u_conf "github.com/arana-db/arana/pkg/util/config" ) const ( @@ -39,23 +36,11 @@ const ( ) type NacosV2Registry struct { - client naming_client.INamingClient - - NamespaceId string - Servers []string // ip+port, like 127.0.0.1:8848 + client *NacosServiceClient } func NewNacosV2Registry(options map[string]interface{}) (base.Registry, error) { - reg := &NacosV2Registry{} - if val, ok := options[u_conf.NamespaceIdKey]; ok { - reg.NamespaceId = val.(string) - } - - if val, ok := options[u_conf.Server]; ok { - reg.Servers = strings.Split(val.(string), u_conf.ServerSplit) - } - - client, err := u_conf.NewNacosV2NamingClient(options) + client, err := NewNacosServiceClient(options) if err != nil { return nil, err } @@ -106,31 +91,20 @@ func (ng *NacosV2Registry) Unregister(ctx context.Context, name string) error { } func (ng *NacosV2Registry) UnregisterAllService(ctx context.Context) error { - // TODO need to deal with cases that the service count is more than pageSize - services, err := ng.client.GetAllServicesInfo(vo.GetAllServiceInfoParam{PageNo: 1, PageSize: 10}) - if err != nil { - return err - } - - for _, srv := range services.Doms { - instances, err := ng.client.SelectAllInstances(vo.SelectAllInstancesParam{ServiceName: srv}) + instances := ng.client.SelectAllServiceInstances() + for _, inst := range instances { + flag, err := ng.client.DeregisterInstance(vo.DeregisterInstanceParam{ + Ip: inst.Ip, + Port: inst.Port, + Cluster: inst.ClusterName, + ServiceName: inst.ServiceName, + Ephemeral: true, + }) if err != nil { return err } - for _, inst := range instances { - flag, err := ng.client.DeregisterInstance(vo.DeregisterInstanceParam{ - Ip: inst.Ip, - Port: inst.Port, - Cluster: inst.ClusterName, - ServiceName: inst.ServiceName, - Ephemeral: true, - }) - if err != nil { - return err - } - if !flag { - logger.Infof("Deregister instance %s failed", inst) - } + if !flag { + logger.Infof("Deregister instance %s failed", inst) } } return nil diff --git a/pkg/util/config/nacos.go b/pkg/util/config/nacos.go index 6312dabf..d2f689be 100644 --- a/pkg/util/config/nacos.go +++ b/pkg/util/config/nacos.go @@ -19,8 +19,9 @@ const ( Username string = "username" Password string = "password" Server string = "endpoints" - ContextPath string = "contextPath" + ContextPath string = "context-path" Scheme string = "scheme" + PageSizeKey string = "page-size" PathSplit string = "::" ServerSplit string = "," From c9664bc90517eccaa20ed883630385f2e82f6e19 Mon Sep 17 00:00:00 2001 From: Mulavar <978007503@qq.com> Date: Wed, 22 Mar 2023 11:04:01 +0800 Subject: [PATCH 3/4] fix --- pkg/registry/nacos/discovery.go | 17 +++++++++++++++++ pkg/util/config/nacos.go | 17 +++++++++++++++++ pkg/util/config/nacos_test.go | 21 +++++++++++++++++++-- 3 files changed, 53 insertions(+), 2 deletions(-) diff --git a/pkg/registry/nacos/discovery.go b/pkg/registry/nacos/discovery.go index 53e554e1..26aaca11 100644 --- a/pkg/registry/nacos/discovery.go +++ b/pkg/registry/nacos/discovery.go @@ -1,3 +1,20 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package nacos import ( diff --git a/pkg/util/config/nacos.go b/pkg/util/config/nacos.go index d2f689be..6c221bbd 100644 --- a/pkg/util/config/nacos.go +++ b/pkg/util/config/nacos.go @@ -1,3 +1,20 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package config import ( diff --git a/pkg/util/config/nacos_test.go b/pkg/util/config/nacos_test.go index 68b581b5..b691f6e7 100644 --- a/pkg/util/config/nacos_test.go +++ b/pkg/util/config/nacos_test.go @@ -1,3 +1,20 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You under the Apache License, Version 2.0 + * (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package config import ( @@ -9,12 +26,12 @@ import ( ) func Test_parseServerConfig(t *testing.T) { - // NamespaceIdKey string = "namespace" + // NamespaceIdKey string = "namespace-id" // GroupKey string = "group" // Username string = "username" // Password string = "password" // Server string = "endpoints" - // ContextPath string = "contextPath" + // ContextPath string = "context-path" // Scheme string = "scheme" options := map[string]interface{}{ From 5ac1480e6e39b25ec6e0ac4b92858968a279845b Mon Sep 17 00:00:00 2001 From: Mulavar <978007503@qq.com> Date: Thu, 23 Mar 2023 10:21:07 +0800 Subject: [PATCH 4/4] fix --- conf/bootstrap.yaml | 4 ++-- example/service_discovery/etcd/main.go | 4 ++-- example/service_discovery/nacos/main.go | 9 ++------- pkg/registry/discovery.go | 4 ++-- pkg/util/config/nacos.go | 4 ++-- pkg/util/config/nacos_test.go | 4 ++-- 6 files changed, 12 insertions(+), 17 deletions(-) diff --git a/conf/bootstrap.yaml b/conf/bootstrap.yaml index ace9184b..f72b4837 100644 --- a/conf/bootstrap.yaml +++ b/conf/bootstrap.yaml @@ -34,9 +34,9 @@ registry: # name: nacos # options: # endpoints: "127.0.0.1:8848" -# namespace-id: arana +# namespace_id: arana # group: arana -# context-path: /nacos +# context_path: /nacos # scheme: http # username: nacos # password: nacos diff --git a/example/service_discovery/etcd/main.go b/example/service_discovery/etcd/main.go index 8b3674c3..56004c1b 100644 --- a/example/service_discovery/etcd/main.go +++ b/example/service_discovery/etcd/main.go @@ -32,8 +32,8 @@ func main() { storeType := base.ETCD options := make(map[string]interface{}) options["endpoints"] = "http://127.0.0.1:2379" - options["rootPath"] = "arana" - options["servicePath"] = "service" + options["root_path"] = "arana" + options["service_path"] = "service" etcdDiscovery, err := registry.InitDiscovery(storeType, options) if err != nil { diff --git a/example/service_discovery/nacos/main.go b/example/service_discovery/nacos/main.go index d9999a1b..d244ac48 100644 --- a/example/service_discovery/nacos/main.go +++ b/example/service_discovery/nacos/main.go @@ -18,11 +18,6 @@ package main import ( - "context" -) - -import ( - "github.com/arana-db/arana/pkg/config" "github.com/arana-db/arana/pkg/registry" "github.com/arana-db/arana/pkg/registry/base" "github.com/arana-db/arana/pkg/util/log" @@ -36,11 +31,11 @@ func main() { options["username"] = "nacos" options["password"] = "nacos" - nacosDiscovery, err := registry.InitRegistry(&config.Registry{Options: options, Name: storeType}) + nacosDiscovery, err := registry.InitDiscovery(base.NACOS, options) if err != nil { log.Fatalf("Init %s discovery err:%v", storeType, err) return } - nacosDiscovery.UnregisterAllService(context.Background()) + nacosDiscovery.GetServices() } diff --git a/pkg/registry/discovery.go b/pkg/registry/discovery.go index 8f6fb02e..845f87d0 100644 --- a/pkg/registry/discovery.go +++ b/pkg/registry/discovery.go @@ -34,8 +34,8 @@ import ( ) const ( - _rootPath = "rootPath" - _servicePath = "servicePath" + _rootPath = "root_path" + _servicePath = "service_path" _endpoints = "endpoints" _defaultServicePath = "service" diff --git a/pkg/util/config/nacos.go b/pkg/util/config/nacos.go index 6c221bbd..e8efd4bd 100644 --- a/pkg/util/config/nacos.go +++ b/pkg/util/config/nacos.go @@ -31,12 +31,12 @@ import ( const ( DefaultGroupName string = "arana" - NamespaceIdKey string = "namespace-id" + NamespaceIdKey string = "namespace_id" GroupKey string = "group" Username string = "username" Password string = "password" Server string = "endpoints" - ContextPath string = "context-path" + ContextPath string = "context_path" Scheme string = "scheme" PageSizeKey string = "page-size" diff --git a/pkg/util/config/nacos_test.go b/pkg/util/config/nacos_test.go index b691f6e7..9f7a5708 100644 --- a/pkg/util/config/nacos_test.go +++ b/pkg/util/config/nacos_test.go @@ -26,12 +26,12 @@ import ( ) func Test_parseServerConfig(t *testing.T) { - // NamespaceIdKey string = "namespace-id" + // NamespaceIdKey string = "namespace_id" // GroupKey string = "group" // Username string = "username" // Password string = "password" // Server string = "endpoints" - // ContextPath string = "context-path" + // ContextPath string = "context_path" // Scheme string = "scheme" options := map[string]interface{}{