当前位置: 首页 > wzjs >正文

文创产品营销方案seo提供服务

文创产品营销方案,seo提供服务,做企业网站设计方案,赤峰网站建设培训学校问题描述 今天遇到一个奇怪问题,我在初始化一个etcd客户端时,传入了一个错误的端点,然后就水灵灵的初始化成功了,没有触发err。 这直接导致后续的etcd操作永久阻塞,而且不利于错误排查。。。。 package mainimport…

问题描述

今天遇到一个奇怪问题,我在初始化一个etcd客户端时,传入了一个错误的端点,然后就水灵灵的初始化成功了,没有触发err。 

这直接导致后续的etcd操作永久阻塞,而且不利于错误排查。。。。

package mainimport ("context""fmt"clientv3 "go.etcd.io/etcd/client/v3""go.uber.org/zap""time"
)func main() {cli, err := clientv3.New(clientv3.Config{Endpoints:   []string{"127.0.0.1:2378"},	// 传入一个错误端口2378DialTimeout: 5 * time.Second,})if err != nil {    // err为 nilfmt.Printf("clientv3.New() err: %v", err)return}}

 后来我查了一下,原因如下:

clientv3.New 在创建客户端时,不会立即验证端点的有效性或是否可连接,而是将验证推迟到实际使用客户端(比如执行 Put、Get 等操作)时。

err 为 nil 并不一定意味着端点是正确的,而是说明 clientv3.New 在初始化时没有检测到明显的配置错误。真正的连接问题可能在后续操作中暴露出来。

解决方式

我们在初始化完成之后,直接验证该端点的有效性。(类似于ping),如果验证出错就 return,验证正确就继续执行。

package mainimport ("context""fmt"clientv3 "go.etcd.io/etcd/client/v3""go.uber.org/zap""time"
)func main() {cli, err := clientv3.New(clientv3.Config{Endpoints:   []string{"127.0.0.1:2378"}, // 传入一个错误端口2378DialTimeout: 5 * time.Second,})if err != nil {fmt.Printf("clientv3.New() err: %v", err)return}// 验证端点有效性ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)defer cancel()_, err = cli.Status(ctx, "127.0.0.1:2378")if err != nil {fmt.Printf("验证端点有效性失败 cli.Status() %v\n", err)cli.Close() // 记得关return}}

实际跑一下,输出如下:

{"level":"warn","ts":"2025-04-03T15:16:38.336886+0800","logger":"etcd-client","caller":"v3@v3.5.12/retry_interceptor.go:62","msg":"retrying of unary invoker failed","target":"etcd-endpoints://0xc0000f61c0/127.0.0.1:2378","attempt":0,"error":"rpc error: code = DeadlineExceeded desc = latest balancer error: connection error: desc = \"transport: Error while dialing: dial tcp 127.0.0.1:2378: connectex: No connection could be made because the target machine actively refused it.\""}
验证端点有效性失败 cli.Status() context deadline exceeded

第一行是clientv3内部自动输出的一条日志,其中描述了错误原因:Error while dialing: dial tcp 127.0.0.1:2378: connectex: No connection could be made because the target machine actively refused it

第二行则是我们手动输出的err,只描述了上下文超时错误。

这样一来,错误的端点就会在此被检查出来,我们就成功实现了验证。

但是,描述了错误原因的这条日志,他只是自动打印在控制台了,并不是打印在日志文件中,这样我们日后还是不方便排查问题,那我们如何将其打印在日志文件中呢?有需求的小伙伴可以继续往下看。 

将报错打印到日志文件

我们只需要在初始化客户端时,加入一个字段即可。

http://www.dtcms.com/wzjs/60327.html

相关文章:

  • 游戏钓鱼网站怎么做cilimao磁力猫最新版地址
  • 有了源代码怎么做网站天眼查企业查询
  • 南宁制作网站公司东莞疫情最新消息今天新增病例
  • 广州网站营销推广设计公司培训课程有哪些
  • 嘉兴 企业网站 哪家电子商务网站建设论文
  • 网站框架布局百度指数数据分析报告
  • 建设网站要服务器吗网络推广要求
  • 珠海市官网网站建设价格大型的营销型网站
  • 传奇霸主网页版太原seo
  • 找公司做网站注意事项四川网站seo
  • 大城b2c网站建设报价松原新闻头条
  • 网站使用自己的服务器培训学校招生方案范文
  • 做vi的网站电商网站网址
  • 中山网站建设方案托管哪里可以学企业管理培训
  • 关于做我女朋友的网站网络推广协议
  • 如何做充值网站长沙seo公司排名
  • 网店美工培训教程seo sem推广
  • 做电影网站需要服务器吗竞价推广账户竞价托管公司
  • 有关网站建设的电子商务论文重庆森林台词
  • 旅游平台网站合作建设方案网络营销推广及优化方案
  • 苏州官网设计山东自助seo建站
  • 做网站平台多少钱怎样做网络推广挣钱
  • 做网站开发需要什么怎么建网页
  • 小程序源码怎么使用的石狮seo
  • 网站反链是什么意思安卓手机优化神器
  • 网站做百度百科业务网站制作
  • 艺术字logo在线生成器裤子seo关键词
  • 响应式网站模板百度推广一般要多少钱
  • 广东城乡建设厅网站信息流优化师面试常见问题
  • 哪种网站今日新闻头条新闻今天