开发过程中,遇到了docker部署的项目 飙升到100%以上
思路就是代码出现了死循环的现象,一直在做什么操作,导致cpu占用率持续增长到100%以上。(超过100%是因为电脑逻辑核数为16[使用命令lscpu],单核疯狂输出,但是不影响全局其他任务)
那根据这样去推理,就需要找到死循环的代码,也就是通过jstack去了解是哪个线程的。
进入容器中,容器中只运行一个进程时,默认PID为1
执行下列命令,获取占用率最高的PID对应的线程信息,查看指定进程中各个线程占用CPU的状态,选出耗时最多、最繁忙的线程id
ps -mp 1 -o THREAD,tid,time|sort -rn -k2 | head
接着将对应的线程id转为十六进制
printf "%x" 281
jstack 1 | grep 119 -A 10