背景:

应用中有多个实现了CommandLineRunner接口的类,其中一个类A单独起了一个线程去执行逻辑,另一个类B也实现了CommandLineRunner接口但是没有new新线程的操作。

现象:

应用部署在k8s平台之上,应用启动后,pod看起来正常,应用日志感觉也正常,但就是无法访问接口,ping或者访问这个接口都是connection refused。

原因:

应用启动后,类A的run方法先启动,并执行其run方法,单独new了一个线程,其日志也正常打印,所以应用看起来正常。

类B启动后,其run方法执行时,因为方法中访问的地址错误,导致抛出地址未知的异常,导致Springboot的主线程直接因为异常退出,但是此时,类A单独启动的线程还存活并且正常打印日志,所以整个应用看起来还是存活的,pod状态也是正常的。

解决:

在类B的run方法中,如果程序抛出异常,直接return,终止整个程序,类A单独启动的线程也就退出了。

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐