golang etcd clientv3.New()不报超时错误的问题解决

正常来说,clietntv3的初始化代码如下:

config := clientv3.Config{
   Endpoints: []string{"localhost:2379"},
   DialTimeout: 2*time.Second,
}
client, err := clientv3.New(config)
if err != nil{
   panic(fmt.Errorf("ectd client init failed! err: %s ", err.Error()))
}

但是,如果使用新版本的客户端( v3.3.x) 。当我们指定到了一个无效的etcd服务端地址时, 即使设置了DialTimeout选项,clientv3.New()函数依然不会抛出任何错误。直到执行后续的etcd命令时候,才会抛出错误。
貌似是新版本使用的新的均衡器带来的问题。
golang etcd clientv3.New()不报超时错误的问题解决_第1张图片
目前正确的使用方法是在New()函数后使用Status函数来检测当前的连接状态, 代码如下:

clientConfig := clientv3.Config{
	Endpoints:   []string{"http://" + *etcdHost},
	DialTimeout: 2 * time.Second,
}

etcd, err := clientv3.New(clientConfig)
if err != nil {
	return nil, errors.Wrap(err, "could not connect to etcd")
}

timeoutCtx, cancel := context.WithTimeout(context.Background(), 2 * time.Second)
defer cancel()
_, err = etcd.Status(timeoutCtx, clientConfig.Endpoints[0])
if err != nil {
	return nil, errors.Wrapf(err, "error checking etcd status: %v", err)
}

详见这条issue https://github.com/etcd-io/etcd/issues/9877

你可能感兴趣的:(Golang,etcd)