SpringBoot应用接口无法访问,但应用看起来正常
背景:应用中有多个实现了CommandLineRunner接口的类,其中一个类A单独起了一个线程去执行逻辑,另一个类B也实现了CommandLineRunner接口但是没有new新线程的操作。现象:应用部署在k8s平台之上,应用启动后,pod看起来正常,应用日志感觉也正常,但就是无法访问接口,ping或者访问这个接口都是connection refused。原因:应用启动后,类A的run方法先启动
·
背景:
应用中有多个实现了CommandLineRunner接口的类,其中一个类A单独起了一个线程去执行逻辑,另一个类B也实现了CommandLineRunner接口但是没有new新线程的操作。
现象:
应用部署在k8s平台之上,应用启动后,pod看起来正常,应用日志感觉也正常,但就是无法访问接口,ping或者访问这个接口都是connection refused。
原因:
应用启动后,类A的run方法先启动,并执行其run方法,单独new了一个线程,其日志也正常打印,所以应用看起来正常。
类B启动后,其run方法执行时,因为方法中访问的地址错误,导致抛出地址未知的异常,导致Springboot的主线程直接因为异常退出,但是此时,类A单独启动的线程还存活并且正常打印日志,所以整个应用看起来还是存活的,pod状态也是正常的。
解决:
在类B的run方法中,如果程序抛出异常,直接return,终止整个程序,类A单独启动的线程也就退出了。
更多推荐
已为社区贡献2条内容
所有评论(0)