使用Springboot的Scheduled
注解框架执行定时任务,发现线上突然不打任何日志了,我们要找到它不打日志的原因
jps 或 top找到执行java程序的pid jstack -l pid > out.dump 复制代码
然后退出容器后,使用docker cp 容器id:out.dump out.dump
拿到本机目录,后用ftp拿到该文件
out.dump
上传上去分析想要找到对应线程,首先你日志得把对应的线程信息打印出来,根据之前打印日志的线程信息,可以知道该找哪个线程
然后找到对应线程打开
找到了阻塞的原因,由于多线程中countdown
之前代码运行报错,导致不能执行countdown
,使得await
阻塞了,我把countdown
放到finally
中就可以解决该问题了