go nacos服务发现

本来想研究一下nacos的服务发现,原来sample这么详细啊,直接运行代码吧:

package main
 
import (
    "fmt"
    "time"
 
    "github.com/nacos-group/nacos-sdk-go/clients"
    "github.com/nacos-group/nacos-sdk-go/clients/naming_client"
    "github.com/nacos-group/nacos-sdk-go/common/constant"
    "github.com/nacos-group/nacos-sdk-go/model"
    "github.com/nacos-group/nacos-sdk-go/util"
    "github.com/nacos-group/nacos-sdk-go/vo"
)
 
func main() {
    sc := []constant.ServerConfig{
        {
            IpAddr: "192.168.100.30",
            Port:   8848,
        },
    }
    //or a more graceful way to create ServerConfig
    _ = []constant.ServerConfig{
        *constant.NewServerConfig("192.168.100.30", 8848),
    }
 
    cc := constant.ClientConfig{
        NamespaceId:         "e525eafa-f7d7-4029-83d9-008937f9d468", //namespace id
        TimeoutMs:           5000,
        NotLoadCacheAtStart: true,
        //LogDir:              "/tmp/nacos/log",
        //    CacheDir:            "/tmp/nacos/cache",
        RotateTime: "1h",
        MaxAge:     3,
        LogLevel:   "debug",
    }
    //or a more graceful way to create ClientConfig
    _ = *constant.NewClientConfig(
        constant.WithNamespaceId("e525eafa-f7d7-4029-83d9-008937f9d468"),
        constant.WithTimeoutMs(5000),
        constant.WithNotLoadCacheAtStart(true),
        //constant.WithLogDir("/tmp/nacos/log"),
        //constant.WithCacheDir("/tmp/nacos/cache"),
        constant.WithRotateTime("1h"),
        constant.WithMaxAge(3),
        constant.WithLogLevel("debug"),
    )
 
    // a more graceful way to create naming client
    client, err := clients.NewNamingClient(
        vo.NacosClientParam{
            ClientConfig:  &cc,
            ServerConfigs: sc,
        },
    )
 
    if err != nil {
        panic(err)
    }
 
    //Register with default cluster and group
    //ClusterName=DEFAULT,GroupName=DEFAULT_GROUP
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.10",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
        Metadata:    map[string]string{"idc": "shanghai"},
    })
 
    //Register with cluster name
    //GroupName=DEFAULT_GROUP
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.11",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        ClusterName: "cluster-a",
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
    })
 
    //Register different cluster
    //GroupName=DEFAULT_GROUP
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.12",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        ClusterName: "cluster-b",
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
    })
 
    //Register different group
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.13",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        ClusterName: "cluster-b",
        GroupName:   "group-a",
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
    })
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.14",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        ClusterName: "cluster-b",
        GroupName:   "group-b",
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
    })
 
    //DeRegister with ip,port,serviceName
    //ClusterName=DEFAULT, GroupName=DEFAULT_GROUP
    //Note:ip=10.0.0.10,port=8848 should belong to the cluster of DEFAULT and the group of DEFAULT_GROUP.
    ExampleServiceClient_DeRegisterServiceInstance(client, vo.DeregisterInstanceParam{
        Ip:          "10.0.0.10",
        Port:        8848,
        ServiceName: "demo.go",
        Ephemeral:   true, //it must be true
    })
 
    //DeRegister with ip,port,serviceName,cluster
    //GroupName=DEFAULT_GROUP
    //Note:ip=10.0.0.10,port=8848,cluster=cluster-a should belong to the group of DEFAULT_GROUP.
    ExampleServiceClient_DeRegisterServiceInstance(client, vo.DeregisterInstanceParam{
        Ip:          "10.0.0.11",
        Port:        8848,
        ServiceName: "demo.go",
        Cluster:     "cluster-a",
        Ephemeral:   true, //it must be true
    })
 
    //DeRegister with ip,port,serviceName,cluster,group
    ExampleServiceClient_DeRegisterServiceInstance(client, vo.DeregisterInstanceParam{
        Ip:          "10.0.0.14",
        Port:        8848,
        ServiceName: "demo.go",
        Cluster:     "cluster-b",
        GroupName:   "group-b",
        Ephemeral:   true, //it must be true
    })
 
    //Get service with serviceName
    //ClusterName=DEFAULT, GroupName=DEFAULT_GROUP
    ExampleServiceClient_GetService(client, vo.GetServiceParam{
        ServiceName: "demo.go",
    })
    //Get service with serviceName and cluster
    //GroupName=DEFAULT_GROUP
    ExampleServiceClient_GetService(client, vo.GetServiceParam{
        ServiceName: "demo.go",
        Clusters:    []string{"cluster-a", "cluster-b"},
    })
    //Get service with serviceName ,group
    //ClusterName=DEFAULT
    ExampleServiceClient_GetService(client, vo.GetServiceParam{
        ServiceName: "demo.go",
        GroupName:   "group-a",
    })
 
    //SelectAllInstance return all instances,include healthy=false,enable=false,weight<=0
    //ClusterName=DEFAULT, GroupName=DEFAULT_GROUP
    ExampleServiceClient_SelectAllInstances(client, vo.SelectAllInstancesParam{
        ServiceName: "demo.go",
    })
 
    //SelectAllInstance
    //GroupName=DEFAULT_GROUP
    ExampleServiceClient_SelectAllInstances(client, vo.SelectAllInstancesParam{
        ServiceName: "demo.go",
        Clusters:    []string{"cluster-a", "cluster-b"},
    })
 
    //SelectAllInstance
    //ClusterName=DEFAULT
    ExampleServiceClient_SelectAllInstances(client, vo.SelectAllInstancesParam{
        ServiceName: "demo.go",
        GroupName:   "group-a",
    })
 
    //SelectInstances only return the instances of healthy=${HealthyOnly},enable=true and weight>0
    //ClusterName=DEFAULT,GroupName=DEFAULT_GROUP
    ExampleServiceClient_SelectInstances(client, vo.SelectInstancesParam{
        ServiceName: "demo.go",
    })
 
    //SelectOneHealthyInstance return one instance by WRR strategy for load balance
    //And the instance should be health=true,enable=true and weight>0
    //ClusterName=DEFAULT,GroupName=DEFAULT_GROUP
    ExampleServiceClient_SelectOneHealthyInstance(client, vo.SelectOneHealthInstanceParam{
        ServiceName: "demo.go",
    })
 
    //Subscribe key=serviceName+groupName+cluster
    //Note:We call add multiple SubscribeCallback with the same key.
    param := &vo.SubscribeParam{
        ServiceName: "demo.go",
        Clusters:    []string{"cluster-b"},
        SubscribeCallback: func(services []model.SubscribeService, err error) {
            fmt.Printf("callback111 return services:%s \n\n", util.ToJsonString(services))
        },
    }
    ExampleServiceClient_Subscribe(client, param)
    param2 := &vo.SubscribeParam{
        ServiceName: "demo.go",
        Clusters:    []string{"cluster-b"},
        SubscribeCallback: func(services []model.SubscribeService, err error) {
            fmt.Printf("callback222 return services:%s \n\n", util.ToJsonString(services))
        },
    }
    ExampleServiceClient_Subscribe(client, param2)
    ExampleServiceClient_RegisterServiceInstance(client, vo.RegisterInstanceParam{
        Ip:          "10.0.0.112",
        Port:        8848,
        ServiceName: "demo.go",
        Weight:      10,
        ClusterName: "cluster-b",
        Enable:      true,
        Healthy:     true,
        Ephemeral:   true,
    })
    //wait for client pull change from server
    time.Sleep(10 * time.Second)
 
    //Now we just unsubscribe callback1, and callback2 will still receive change event
    ExampleServiceClient_UnSubscribe(client, param)
    ExampleServiceClient_DeRegisterServiceInstance(client, vo.DeregisterInstanceParam{
        Ip:          "10.0.0.112",
        Ephemeral:   true,
        Port:        8848,
        ServiceName: "demo.go",
        Cluster:     "cluster-b",
    })
    //wait for client pull change from server
    time.Sleep(10 * time.Second)
 
    //GeAllService will get the list of service name
    //NameSpace default value is public.If the client set the namespaceId, NameSpace will use it.
    //GroupName default value is DEFAULT_GROUP
    ExampleServiceClient_GetAllService(client, vo.GetAllServiceInfoParam{
        PageNo:   1,
        PageSize: 10,
    })
 
    ExampleServiceClient_GetAllService(client, vo.GetAllServiceInfoParam{
        NameSpace: "0e83cc81-9d8c-4bb8-a28a-ff703187543f",
        PageNo:    1,
        PageSize:  10,
    })
}
 
/*--------------------------------------------------------------------------*/
func ExampleServiceClient_RegisterServiceInstance(client naming_client.INamingClient, param vo.RegisterInstanceParam) {
    success, _ := client.RegisterInstance(param)
    fmt.Printf("RegisterServiceInstance,param:%+v,result:%+v \n\n", param, success)
}
 
func ExampleServiceClient_DeRegisterServiceInstance(client naming_client.INamingClient, param vo.DeregisterInstanceParam) {
    success, _ := client.DeregisterInstance(param)
    fmt.Printf("DeRegisterServiceInstance,param:%+v,result:%+v \n\n", param, success)
}
 
func ExampleServiceClient_GetService(client naming_client.INamingClient, param vo.GetServiceParam) {
    service, _ := client.GetService(param)
    fmt.Printf("GetService,param:%+v, result:%+v \n\n", param, service)
}
 
func ExampleServiceClient_SelectAllInstances(client naming_client.INamingClient, param vo.SelectAllInstancesParam) {
    instances, _ := client.SelectAllInstances(param)
    fmt.Printf("SelectAllInstance,param:%+v, result:%+v \n\n", param, instances)
}
 
func ExampleServiceClient_SelectInstances(client naming_client.INamingClient, param vo.SelectInstancesParam) {
    instances, _ := client.SelectInstances(param)
    fmt.Printf("SelectInstances,param:%+v, result:%+v \n\n", param, instances)
}
 
func ExampleServiceClient_SelectOneHealthyInstance(client naming_client.INamingClient, param vo.SelectOneHealthInstanceParam) {
    instances, _ := client.SelectOneHealthyInstance(param)
    fmt.Printf("SelectInstances,param:%+v, result:%+v \n\n", param, instances)
}
 
func ExampleServiceClient_Subscribe(client naming_client.INamingClient, param *vo.SubscribeParam) {
    client.Subscribe(param)
}
 
func ExampleServiceClient_UnSubscribe(client naming_client.INamingClient, param *vo.SubscribeParam) {
    client.Unsubscribe(param)
}
 
func ExampleServiceClient_GetAllService(client naming_client.INamingClient, param vo.GetAllServiceInfoParam) {
    service, _ := client.GetAllServicesInfo(param)
    fmt.Printf("GetAllService,param:%+v, result:%+v \n\n", param, service)
}

运行结果:

 

 

posted on 2021-03-31 22:27  dz45693  阅读(3758)  评论(0编辑  收藏  举报

导航