集群环境,版本迭代需要停止后台服务,便有了几点注意事项
- 需要在系统活跃度低的时候进行
- 在进行的请求要执行完毕
- 服务关闭中不接收新的请求
- 通知网关不再向关闭的实例分发请求
通过 Springboot 配置文件的配置,即可以解决 2,3
项目发布的时候,后台服务需要关闭,更新 jar 包后 重新启动,但是如果直接关闭,Springboot 默认情况下会直接关闭 tomcat ,导致一些正在进行的请求中断
通过如下配置,实现 Springboot 项目 停止的时候,进行优雅的关闭
server:
port: 8000
shutdown: graceful
spring:
lifecycle:
timeout-per-shutdown-phase: 30s
Shutdown 这是一个枚举类 有两个属性,配合合理的等待时间,实现 springboot 项目优雅关闭。
拓展
正常 Linux 系统 执行 kill 也就是 kill -15
kill 程序时有以下特点
系统会发送一个SIGTERM的信号给对应的程序。当程序接收到该signal后,将会发生以下的事情
程序立刻停止
当程序释放相应资源后再停止
程序可能仍然继续运行
大部分程序接收到SIGTERM信号后,会先释放自己的资源,然后在停止。但是也有程序可以在接受到信号量后,做一些其他的事情,并且这些事情是可以 配置的。如果程序正在等待IO,可能就不会立马做出相应。也就是说,SIGTERM多半是会被阻塞的、忽略
所以如果不配置 graceful,直接 kill java 进程,正在执行的 进程就会被停止。