有关包的安装
我们要实现go语言对第三方包的操作需要我们下载第三方包go.etcd.io
,下载命令:
go get go.etcd.io/etcd/client/v3
ectd的put与get操作
相关函数说明与示例
我们想实现对etcd进行简单的操作的步骤还是比较简单的,在我上一篇文章中,我们基于命令行实现了客户端对服务端的的put/get操作,步骤主要是以下两步:
- 打开服务端
- 客户端连接服务端并完成相关操作
如果不是很清晰的话可以参考博主上一篇博文:
go语言并发实战——日志收集系统(七) etcd的介绍与简单使用
而现在我们想实现go语言操作etcd完成get/put操作其实主要也是和商户步骤基本一致:
- 初始化客户端连接服务端:
cli, err := clientv3.New(clientv3.Config{ Endpoints: []string{"127.0.0.1:2379"}, //服务端通信端口 DialTimeout: 5 * time.Second, //连接超时时间 }) if err != nil { fmt.Println("init client failed,err:%v", err) return } fmt.Println("init client success!") defer cli.Close()
- 执行相关操作
Get函数与Put函数的函数签名为:
Put(ctx context.Context, key, val string, opts ...OpOption) (*PutResponse, error) Get(ctx context.Context, key string, opts ...OpOption) (*GetResponse, error)
我们可以发现它们的参数中存在Context上下文,如果不清楚的话可以参考博主之前的博文:
go语言并发编程(五) ——Context
所以我们可以这样实现get/put操作:
- put操作:
//put ctx, cancel := context.WithTimeout(context.Background(), time.Second) _, err = cli.Put(ctx, "me", "fengxu") cancel() if err != nil { fmt.Println("put failed,err:%v", err) return }
- get操作:
//get ctx, cancel = context.WithTimeout(context.Background(), time.Second) res, err := cli.Get(ctx, "me") cancel() if err != nil { fmt.Println("get failed,err:%v", err) return } for _, ev := range res.Kvs { fmt.Printf("%s:%s\n", ev.Key, ev.Value) }
完整代码以及结果示例
- 完整代码:
package main import ( "context" "fmt" clientv3 "go.etcd.io/etcd/client/v3" "time" ) func main() { cli, err := clientv3.New(clientv3.Config{ Endpoints: []string{"127.0.0.1:2379"}, //服务端通信端口 DialTimeout: 5 * time.Second, //连接超时时间 }) if err != nil { fmt.Println("init client failed,err:%v", err) return } fmt.Println("init client success!") defer cli.Close() //put ctx, cancel := context.WithTimeout(context.Background(), time.Second) _, err = cli.Put(ctx, "me", "fengxu") cancel() if err != nil { fmt.Println("put failed,err:%v", err) return } //get ctx, cancel = context.WithTimeout(context.Background(), time.Second) res, err := cli.Get(ctx, "me") cancel() if err != nil { fmt.Println("get failed,err:%v", err) return } for _, ev := range res.Kvs { fmt.Printf("%s:%s\n", ev.Key, ev.Value) } }
我们打开服务端,运行代码结果为:
etcd的watch操作
watch操作的作用
在etcd中,watch操作可以让我们实时完成对键值操作的实时监控。
watch操作函数的实现
rch := cli.Watch(context.Background(), "me") for wresp := range rch { for _, ev := range wresp.Events { fmt.Printf("Type:%s Key:%s Value:%s\n", ev.Type, ev.Kv.Key, ev.Kv.Value) } }
完整代码及示例
代码:
package main import ( "context" "fmt" clientv3 "go.etcd.io/etcd/client/v3" "time" ) func main() { cli, err := clientv3.New(clientv3.Config{ Endpoints: []string{"127.0.0.1:2379"}, //服务端通信端口 DialTimeout: 5 * time.Second, //连接超时时间 }) if err != nil { fmt.Println("init client failed,err:%v", err) return } fmt.Println("init client success!") defer cli.Close() rch := cli.Watch(context.Background(), "me") for wresp := range rch { for _, ev := range wresp.Events { fmt.Printf("Type:%s Key:%s Value:%s\n", ev.Type, ev.Kv.Key, ev.Kv.Value) } } }
我们运行该程序,尝试在命令行打开客户端对键值对进行操作:
运行结果为:
这样我们就成功实现了watch操作了!
结语
我们有关go简单操作etcd到此为止了,后面就是介绍如何在日志收集服务中使用了,我们下篇见!