[GO] go使用etcd和watch方法进行实时的配置变更
生活随笔
收集整理的這篇文章主要介紹了
[GO] go使用etcd和watch方法进行实时的配置变更
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
監控代碼
package mainimport ("go.etcd.io/etcd/clientv3""time""fmt""context" )func main() {cli, err := clientv3.New(clientv3.Config{Endpoints:[]string{"localhost:2379", "localhost:23279", "localhost:33279"},//etcd集群三個實例的端口DialTimeout:2*time.Second,})if err != nil {fmt.Println("connect failed, err:", err)return}fmt.Println("connect succ")defer cli.Close()for true {rch := cli.Watch(context.Background(), "/logagent/conf/")//阻塞在這里,如果沒有key里沒有變化,就一直停留在這里for wresp := range rch{for _, ev := range wresp.Events{fmt.Printf("%s %q:%q\n", ev.Type, ev.Kv.Key, ev.Kv.Value)}}} }配置變更代碼
package mainimport ("go.etcd.io/etcd/clientv3""time""fmt""context" )func main() {cli, err := clientv3.New(clientv3.Config{Endpoints:[]string{"localhost:2379", "localhost:23279", "localhost:33279"}, //etcd的集群的三個實例端口DialTimeout: 5*time.Second,})if err != nil {fmt.Println("connect failed, err:", err)return}fmt.Println("connect succ")defer cli.Close()ctx, cancel := context.WithTimeout(context.Background(), 2*time.Second)_, err = cli.Put(ctx, "/logagent/conf/", "samplevalue")cancel()if err != nil {fmt.Println("put failed, err:", err)return}ctx, cancel = context.WithTimeout(context.Background(), time.Second)resp, err := cli.Get(ctx, "/logagent/conf/")cancel()if err != nil {fmt.Println("get failed, err:", err)return}for _, ev := range resp.Kvs{fmt.Printf("%s:%s\n", ev.Key, ev.Value)} }
執行后,?監控代碼的執行結果為
轉載于:https://www.cnblogs.com/baylorqu/p/9999405.html
總結
以上是生活随笔為你收集整理的[GO] go使用etcd和watch方法进行实时的配置变更的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: maven nexus memory
- 下一篇: ArcGis辅助编号(半自动)功能的插件