Go-Zero】Windows启动rpc服务报错panic:context deadline exceeded解决方案

大家好 我是寸铁👊
总结了一篇Windows11下启动rpc服务报错panic解决方案的文章✨
喜欢的小伙伴可以点点关注 💝

问题来源

今天在编写完proto文件后,使用goctl生成对应的rpc 服务文件时,启动rpc 服务,发现panic 报错。

goctl命令

// rpc目录下创建
goctl rpc protoc user.proto --go_out=types --go-grpc_out=types --zrpc_out=.

报错信息

报错信息如下:

在这里插入图片描述

具体如下:

panic: context deadline exceeded
goroutine 1 [running]:
github.com/zeromicro/go-zero/zrpc.(*RpcServer).Start(0x28d3ec0?)
D:/Environment/GoWorks/pkg/mod/github.com/zeromicro/go-zero@v1.6.1/zrpc/server.go:89 +0x75
main.main()
D:/GoProject/zero_study/user/rpc/user.go:38 +0x299
exit status 2


排查

方法1

是不是其他进程的占用了启动rpc 服务的默认端口:2379
需要先把进程关闭,再启动服务。
必要时,重启电脑,试一下


检查2379端口是否被占用
cmd窗口中使用如下命令

netstat -ano

如果出现在这上面,说明端口已被占用!
不过这里的报错一般不是这个问题导致报错,大部分是etcd 启动问题,见下面方法2


在这里插入图片描述


方法2(优先尝试)

假如不是上面的原因引起的,则说明是因为etcd 服务没有启动!
为什么?
这里需要简单了解一下rpc 的原理
查阅一下官方文档
在这里插入图片描述

这说明使用goctl生成rpc服务时会默认向etcd注册中心注册当前服务的信息,也就是说etcd需要开启,才能接收到生成的rpc服务发送过来的信息!


在清楚这个原理后,只需要启动etcd 服务即可。

假如你还没有安装etcd ,那么需要先安装一下。
具体安装教程见这篇博客


如果你已经安装,那么需要手动打开一下

  • 首先,找到你安装etcd 的文件夹
    在这里插入图片描述

  • 接着,需要在路径框输入cmd

在这里插入图片描述

  • 最后,在启动的窗口中输入etcd 即可

在这里插入图片描述


之后再回到goland去启动rpc 服务即可!

在这里插入图片描述

现在,就可以正常启动rpc 服务啦!


看到这里的小伙伴,恭喜你又掌握了一个技能👊
希望大家能取得胜利,坚持就是胜利💪
我是寸铁!我们下期再见💕

往期好文💕

保姆级教程

【保姆级教程】Windows11下go-zero的etcd安装与初步使用

【保姆级教程】Windows11安装go-zero代码生成工具goctl、protoc、go-zero

Go-Zero】手把手带你在goland中创建api文件并设置高亮


报错解决

Go-Zero】Error: user.api 27:9 syntax error: expected ‘:‘ | ‘IDENT‘ | ‘INT‘, got ‘(‘ 报错解决方案及api路由注意事项

Go-Zero】Error: only one service expected goctl一键转换生成rpc服务错误解决方案

Go-Zero】【error】 failed to initialize database, got error Error 1045 (28000):报错解决方案

Go-Zero】Error 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)报错解决方案

Go-Zero】type mismatch for field “Auth.AccessSecret“, expect “string“, actual “number“报错解决方案

Go-Zero】Error: user.api 30:2 syntax error: expected ‘)‘ | ‘KEY‘, got ‘IDENT‘报错解决方案

Go-Zero】Windows启动rpc服务报错panic:context deadline exceeded解决方案


Go面试向

Go面试向】defer与time.sleep初探

Go面试向】defer与return的执行顺序初探

【Go面试向】Go程序的执行顺序

Go面试向】rune和byte类型的认识与使用

Go面试向】实现map稳定的有序遍历的方式

Logo

一起探索未来云端世界的核心,云原生技术专区带您领略创新、高效和可扩展的云计算解决方案,引领您在数字化时代的成功之路。

更多推荐