背景:
应用中有多个实现了CommandLineRunner接口的类,其中一个类A单独起了一个线程去执行逻辑,另一个类B也实现了CommandLineRunner接口但是没有new新线程的操作。
现象:
应用部署在k8s平台之上,应用启动后,pod看起来正常,应用日志感觉也正常,但就是无法访问接口,ping或者访问这个接口都是connection refused。
原因:
应用启动后,类A的run方法先启动,并执行其run方法,单独new了一个线程,其日志也正常打印,所以应用看起来正常。
类B启动后,其run方法执行时,因为方法中访问的地址错误,导致抛出地址未知的异常,导致Springboot的主线程直接因为异常退出,但是此时,类A单独启动的线程还存活并且正常打印日志,所以整个应用看起来还是存活的,pod状态也是正常的。
解决:
在类B的run方法中,如果程序抛出异常,直接return,终止整个程序,类A单独启动的线程也就退出了。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)