首页 > 其他 > 详细

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

时间:2020-07-23 21:30:18      阅读:249      评论:0      收藏:0      [点我收藏+]

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

技术分享图片

 

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

原文:https://www.cnblogs.com/kongkongFabian/p/13367441.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!