etcd接入中的前后端数据不一致问题
在尝试将golang连接到etcd时,可能会遇到数据读写不一致的问题:
- etcd已部署
- etcdctl命令可用
- 代码可以运行并获取值
- 但etcdctl却无法找到该值
示例代码:
package main
import (
"context"
"fmt"
"go.etcd.io/etcd/clientv3"
)
func main() {
cli, err := clientv3.new(clientv3.config{
endpoints: []string{"127.0.0.1:2379"},
})
if err != nil {
panic(err)
}
// 写入值
key := "foo"
val := "bar"
_, err = cli.put(context.background(), key, val)
if err != nil {
panic(err)
}
// 读取值
resp, err := cli.get(context.background(), key)
if err != nil {
panic(err)
}
fmt.println("value:", resp.kvs[0].value)
}通过etcdctl无法获取到代码中写入的值:
etcdctl get foo foo not found
原因与解决方法
立即学习“go语言免费学习笔记(深入)”;
出现这种情况的原因是,go代码使用了etcd的v3接口,而etcdctl可能仍使用v2接口。因此,需要使用etcdctl v3来操作v3接口:
etcdctl --version=3 get foo bar










