-
Notifications
You must be signed in to change notification settings - Fork 556
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
windows下:Spin即使没有任何请求正在处理,server依然会等ExitWaitTimeout秒后退出 #878
Comments
This issue has been marked as invalid question, please give more information by following the |
hi @xiaotushaoxia 改下 issue 模版吧,否则可可能会被自动close。 |
@xiaotushaoxia 赞,这个 diff 是标准网络库和 netpoll 实现上没有完全对齐。我记录一个 TODO,有兴趣的话也非常欢迎 PR 哈~ |
嗯。我的想法是参考net.http实现。net.http中的conn会记录状态 New Idle Active, server(hzrtz中的Transporter) shutdown的时候在ctx.Done前一次次关闭全部Idle的conn,直到全部连接关闭。
2的主要问题是要记录全部conn需要加锁,不知道会不会有性能影响(不过可能是杞人忧天,不要提前优化....) |
个人感觉如果有性能损失的话&不如不完善 win 的体验😞,原因是服务实际部署大概率还是在 linux 上部署,win 更多是开发调试👀 |
嗯。本来就是为了高性能做的这个,我翻了下issues,看到也有提到hertz因为性能舍弃一些边缘功能的评论。 |
netpoll的shutdown其实是符合预期的:进入graceful阶段会将正在进行中的响应置为短连接,若所有长链接都被正常关闭后则提前退出,否则等待到用户配置的最大退出时间。 直接在graceful进入的时刻批量关闭所有idle状态的链接,这个行为我不认为比上述行为更优:它并不会额外降低连接关闭时刻的并发问题。并且仅是在idle连接退出时间上的一点区别。 |
这个问题,在macOS m2-arm64上面也会出现。现象是,如果hertz启动后没有任何请求,关闭和重启都是瞬间完成。如果有过一个请求,点击关闭和重启,就需要等待5s。 |
@zhouguanglong1 这个是符合预期的,大概率是因为你的链接没有关闭(浏览器默认都是长链接),这个可以本地使用telnet模拟,关闭链接的话直接ctrl-C就可以。 |
Describe the Question
windows下:Spin即使没有任何请求正在处理,server依然会等ExitWaitTimeout秒后退出
Reproducible Code
开启后直接ctrl+c,程序依然会等待。
看了下问题应该出在
github.com\cloudwego\hertz\pkg\network\standard\transport.go 112行。因为ubuntu下使用netpoll.transport,和standard.standard的Shutdown实现不一样,所以只在windows下存在问题。
参考net.http的shutdown实现,net.http.Server会记录所有客户端,Shutdown后有在ctx.Done前尝试去关闭全部客户端,如果客户端已经退出了,Shutdown就直接返回。hertz.Server似乎没有记下全部客户端,所以Shutdown硬等到ctx.Done, 这个实现应该是有瑕疵的
Hertz version:
v0.6.6
The text was updated successfully, but these errors were encountered: