ZBLOG

golang etcd go 驱动包操作

etcd是一个高可用的分布式键值存储系统,常用于服务发现、配置共享等场景。在Golang中,可以使用go-etcd/etcd包来进行对etcd的操作。

以下是一些常用的操作:

  1. 连接etcd服务器
import (
    "context"
    "github.com/coreos/etcd/clientv3"
)

// 创建etcd客户端
cli, err := clientv3.New(clientv3.Config{
        Endpoints:   []string{"localhost:2379"}, // etcd服务器地址
        DialTimeout: 5 * time.Second,
})
if err != nil {
    log.Fatal(err)
}

defer cli.Close() // 关闭连接
  1. 写入数据
// 写入数据,key为“foo”,value为“bar”
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
_, err = cli.Put(ctx, "foo", "bar")
cancel()
if err != nil {
    log.Fatal(err)
}
  1. 读取数据
// 读取数据,key为“foo”
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
resp, err := cli.Get(ctx, "foo")
cancel()
if err != nil {
    log.Fatal(err)
}

for _, ev := range resp.Kvs {
	fmt.Printf("%s : %s\n", ev.Key, ev.Value)
}
  1. 监听变化
// 监听前缀为“foo”的key变化
ctx, cancel := context.WithCancel(context.Background())
respChan := cli.Watch(ctx, "foo", clientv3.WithPrefix())

for resp := range respChan {
	for _, ev := range resp.Events {
		fmt.Printf("%s %q : %q\n", ev.Type, ev.Kv.Key, ev.Kv.Value)
	}
}

以上是一些常用的操作,还有其他操作(如删除数据、事务处理等)可以参考etcd官方文档和go-etcd/etcd包的API文档。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=6721

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?