in example/zk_client/zk_client.go [30:162]
func main() {
//Create ShenYuZkClient start
zcp := &zk_client.ZkClientParam{
ZkServers: []string{"127.0.0.1:2181"}, //require user provide
ZkRoot: "/api", //require user provide
}
sdkClient := shenyu_sdk_client.GetFactoryClient(constants.ZOOKEEPER_CLIENT)
client, createResult, err := sdkClient.NewClient(zcp)
if !createResult && err != nil {
fmt.Printf("Create ShenYuZkClient error : %v", err)
}
zc := client.(*zk_client.ShenYuZkClient)
defer zc.Close()
//Create ShenYuZkClient end
//RegisterServiceInstance start
//init MetaDataRegister
metaData1 := &model.MetaDataRegister{
AppName: "testMetaDataRegister1", //require user provide
Path: "your/path1", //require user provide
Enabled: true, //require user provide
Host: "127.0.0.1", //require user provide
Port: "8080", //require user provide
}
metaData2 := &model.MetaDataRegister{
AppName: "testMetaDataRegister2", //require user provide
Path: "your/path2", //require user provide
Enabled: true, //require user provide
Host: "127.0.0.1", //require user provide
Port: "8181", //require user provide
}
metaData3 := &model.MetaDataRegister{
AppName: "testMetaDataRegister3", //require user provide
Path: "your/path3", //require user provide
Enabled: true, //require user provide
Host: "127.0.0.1", //require user provide
Port: "8282", //require user provide
}
//register multiple metaData
registerResult1, err := zc.RegisterServiceInstance(metaData1)
if !registerResult1 && err != nil {
fmt.Printf("Register zk Instance error : %v", err)
}
registerResult2, err := zc.RegisterServiceInstance(metaData2)
if !registerResult2 && err != nil {
fmt.Printf("Register zk Instance error : %v", err)
}
registerResult3, err := zc.RegisterServiceInstance(metaData3)
if !registerResult3 && err != nil {
fmt.Printf("Register zk Instance error : %v", err)
}
//RegisterServiceInstance end
time.Sleep(time.Second)
//GetServiceInstanceInfo start
instanceDetail, err := zc.GetServiceInstanceInfo(metaData1)
nodes1, ok := instanceDetail.([]*model.MetaDataRegister)
if !ok {
fmt.Printf("get zk client metaData error %v:", err)
}
//range nodes
for index, node := range nodes1 {
nodeJson, err := json.Marshal(node)
if err == nil {
fmt.Printf("GetNodesInfo ,success Index %v,%v", index, string(nodeJson))
}
}
instanceDetail2, err := zc.GetServiceInstanceInfo(metaData2)
nodes2, ok := instanceDetail2.([]*model.MetaDataRegister)
if !ok {
fmt.Printf("get zk client metaData error %v:", err)
}
//range nodes1
for index, node := range nodes2 {
nodeJson, err := json.Marshal(node)
if err == nil {
fmt.Printf("GetNodesInfo ,success Index %v,%v", index, string(nodeJson))
}
}
instanceDetail3, err := zc.GetServiceInstanceInfo(metaData3)
nodes3, ok := instanceDetail3.([]*model.MetaDataRegister)
if !ok {
fmt.Printf("get zk client metaData error %v:", err)
}
for index, node := range nodes3 {
nodeJson, err := json.Marshal(node)
if err == nil {
fmt.Printf("GetNodesInfo ,success Index %v,%v", index, string(nodeJson))
}
}
//GetServiceInstanceInfo end
//DeregisterServiceInstance start
//your can chose to invoke,not require
fmt.Printf("> DeregisterServiceInstance start")
deRegisterResult1, err := zc.DeregisterServiceInstance(metaData1)
if err != nil {
panic(err)
}
deRegisterResult2, err := zc.DeregisterServiceInstance(metaData2)
if err != nil {
panic(err)
}
deRegisterResult3, err := zc.DeregisterServiceInstance(metaData3)
if err != nil {
panic(err)
}
if deRegisterResult1 && deRegisterResult2 && deRegisterResult3 {
fmt.Printf("DeregisterServiceInstance success !")
}
//DeregisterServiceInstance end
//do your logic
}