go - etcd 错误:超出上下文截止日期
问题描述
当我使用 shell 时它返回 ok,但是当我使用 golang 时它返回err: context deadline exceeded
.
为什么?
package main
import (
"context"
"fmt"
"go.etcd.io/etcd/clientv3"
"time"
)
func main() {
cli,err := clientv3.New(clientv3.Config{
Endpoints: []string{"http://192.168.11.34:2379"},
DialTimeout: 5*time.Second,
})
if err != nil{
panic(err)
}
fmt.Println("connect etcd success!")
defer cli.Close()
ctx,cancel := context.WithTimeout(context.Background(),time.Second*5)
_,err = cli.Put(ctx,"mac","leave")
defer cancel()
if err !=nil{
fmt.Println("put etcd err:",err.Error())
return
}
}
connect etcd success!
{"level":"warn","ts":"2021-02-08T17:10:46.490+0800","caller":"clientv3/retry_interceptor.go:62","msg":"retrying of unary invoker failed","target":"endpoint://client-5b14f6c4-2395-4a15-9ebb-cadf5985fb06/192.168.11.34:2379","attempt":0,"error":"rpc error: code = DeadlineExceeded desc = latest balancer error: all SubConns are in TransientFailure, latest connection error: connection error: desc = \"transport: Error while dialing dial tcp 192.168.11.34:2379: connect: connection refused\""}
put etcd err: context deadline exceeded
解决方案
创建客户端并不能保证连接已建立。它可能会延迟到第一个实际失败的请求。
请确保您的服务器是可访问的。
推荐阅读
- python - PyQt5从输入值自动绘图
- c# - 为什么我的 RLE 的最后一个字符不显示?
- sql - 如何在元组中选择最旧的值
- java - ArrayLists 数组的未检查或不安全操作错误
- javascript - Vuex:根据已获取的数据使用 axios 获取数据
- javascript - RxJS 5,Angular:如何每 x 秒执行一次请求,直到消息匹配某个字符串?
- python - 熊猫:从其他列的值填充新列
- sql - 谷歌表格查询 - 为没有记录数据的日期填充零
- javascript - 如何在 JavaScript 中将字符串分成三部分
- r - 编写一个函数来检查一个字符串是否符合十六进制表示法