有关包的安装
我们要实现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操作:
- get操作:
//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
}
- put操作:
//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到此为止了,后面就是介绍如何在日志收集服务中使用了,我们下篇见!