- 问题表现:每次服务发版的过程中都会报错
Grafana监控:
ELK日志:
- 解决方案:参考了这篇文章 在Kubernetes中实现优雅退出 才彻底的解决了问题。
- 设置优雅关机
server:
shutdown: graceful
- K8S设置事件回调,在执行停止命令前把服务节点从注册中心下线,不再接收新的请求流量,再睡一会儿,让先让容器的网关规则完成变更。
对应的yml配置:
设置强制杀掉服务的时间:terminationGracePeriodSeconds: 95
完成以上的操作,springboot默认优雅关机的时间30秒+preStopHook50秒 < 强制杀掉的时间95秒,这样子就能保证旧的pod能完成正在处理中的请求,而且新的流量不会转发已经被删除掉的pod中。