CentOS中docker部署的项目CPU占用率持续100%以上

开发过程中,遇到了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

 

posted @ 2020-07-23 17:15  eros_token  阅读(3152)  评论(0编辑  收藏  举报