需求场景
干净利落地升级正在运行的agent程序。适用于Devops团队。html
目标:nginx
-
不关闭现有链接:例如咱们不但愿关掉已部署的运行中的程序。但又想不受限制地随时升级服务。git
-
新的进程要可以启动并替换掉旧的。github
原理:golang
在基于Unix的操做系统中,signal(信号)是与长时间运行的进程交互的经常使用方法.web
-
SIGTERM: 优雅地中止进程apache
-
SIGHUP: 重启/从新加载进程 (例如: nginx, sshd, apache)centos
若是收到SIGHUP信号,优雅地重启进程须要如下几个步骤:服务器
-
服务器要拒绝新的链接请求,但要保持已有的链接。ssh
-
启用新版本的进程
-
将socket“交给”新进程,新进程开始接受新链接请求
-
旧进程处理完毕后当即中止。
实现参考:
https://grisha.org/blog/2014/06/03/graceful-restart-in-golang/ beego的grace模块主要的思路来源也是参考这篇文章
注意
一、实现后的agent程序,通常都是注册在systemd中(centos 7),咱们准备的xxx.service文件须要指明PIDFile,这样在进行kill -HUP <server pid>时不会致使因systemd探测产生进程启动失败。
二、程序自支持kill -HUP,能够在代码中实现,经过这个方式这样能够经过控制台端随意的升级哪台agent。
升级步骤:
- 调用agent端接口,发送升级指令
- agent版本下载
- agent备份、替换程序包
- 执行kill -HUP
- 完成自升级