- 问题表现:每次服务发版的过程中都会报错
Grafana监控:

ELK日志:

- 解决方案:参考了这篇文章 在Kubernetes中实现优雅退出 才彻底的解决了问题。
- 设置优雅关机
server:
shutdown: graceful
- K8S设置事件回调,在执行停止命令前把服务节点从注册中心下线,不再接收新的请求流量,再睡一会儿,让先让容器的网关规则完成变更。

对应的yml配置:

设置强制杀掉服务的时间:terminationGracePeriodSeconds: 95
完成以上的操作,springboot默认优雅关机的时间30秒+preStopHook50秒 < 强制杀掉的时间95秒,这样子就能保证旧的pod能完成正在处理中的请求,而且新的流量不会转发已经被删除掉的pod中。

博客指出服务发版过程中会报错,通过参考在Kubernetes中实现优雅退出的文章解决问题。设置优雅关机,在K8S设置事件回调,让服务节点提前下线,还给出对应的yml配置,设置强制杀服务时间,确保旧pod完成请求且新流量不转发到已删pod。
2590

被折叠的 条评论
为什么被折叠?



