beego高级编程---->grace模块热重启导致旧进程未处理完请求直接退出

asd1123509133 · · 2040 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

背景:

聽聽聽聽聽聽聽聽热升级是什么呢?了解nginx的同学都知道,nginx是支持热升级的,可以用老进程服务先前链接的链接,使用新进程服务新的链接,即在不停止服务的情况下完成系统的升级与运行参数修改。

环境:

wKiom1iX8jjS6H_mAABkLwCMumo332.jpg-wh_50


原因:

聽 聽 聽聽聽聽沿着beego官方文档开启Graceful后, 运行kill -HUP pid重启进程的时候, 旧连接其实并没有继续处理, 而是直接关闭了随着旧进程,导致请求返回504


解决:

聽聽聽聽聽聽聽聽看了代码是在grace/server.go中process.Kill()的时候把新进程的父进程直接杀死, 发送的是SIGKILL信号,进程不会处理,直接被杀死,其实在handleSignals函数里面也确实没有处理这种信号。所以,代码改为如下:
文件:grace/server.go, 函数ListenAndServe()以及 ListenAndServeTLS()

 聽 聽//err = process.Kill()
聽 聽 聽err = process.Signal(os.Interrupt)


最后:

聽聽聽聽聽聽聽聽经过测试可以正常处理完未完成的连接。



以需求驱动技术,技术本身没有优略之分,只有业务之分。

本文出自 “sea” 博客,请务必保留此出处http://lisea.blog.51cto.com/5491873/1895219


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

2040 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传