需求场景

干净利落地升级正在运行的agent程序。适用于Devops团队。html

目标:nginx

  • 不关闭现有链接:例如咱们不但愿关掉已部署的运行中的程序。但又想不受限制地随时升级服务。git

  • 新的进程要可以启动并替换掉旧的。github

原理:golang

在基于Unix的操做系统中,signal(信号)是与长时间运行的进程交互的经常使用方法.web

  • SIGTERM: 优雅地中止进程apache

  • SIGHUP: 重启/从新加载进程 (例如: nginx, sshd, apache)centos

若是收到SIGHUP信号,优雅地重启进程须要如下几个步骤:服务器

  1. 服务器要拒绝新的链接请求,但要保持已有的链接。ssh

  2. 启用新版本的进程

  3. 将socket“交给”新进程,新进程开始接受新链接请求

  4. 旧进程处理完毕后当即中止。

 

实现参考:

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。

升级步骤:

  1. 调用agent端接口,发送升级指令
  2. agent版本下载
  3. agent备份、替换程序包
  4. 执行kill -HUP
  5. 完成自升级