查看Linux进程CPU过高具体的线程堆栈(不中断程序)

http://www.linuxdiyf.com/linux/18227.html

1、TOP命令,找到占用CPU最高的进程

$ top

top - 20:11:45 up 850 days,  1:18,  3 users,  load average: 1.04, 1.01, 0.99

Tasks:  61 total,   1 running,  60 sleeping,   0 stopped,   0 zombie

Cpu(s):  1.4% us,  0.1% sy,  0.0% ni, 98.3% id,  0.1% wa,  0.0% hi,  0.2% si

Mem:  16418172k total, 15693376k used,   724796k free,  1146696k buffers

Swap: 10223608k total,0k used, 10223608k free, 12537692k cached

PID USER  PR  NI  VIRT  RES  SHR S %CPU %MEMTIME+  COMMAND

24714 ztgame16   0 1409m 1.2g 4252 S 99.6  7.4   2390:57 IMVChannelServe

1 root  16   0  4772  520  432 S  0.0  0.0   0:03.43 init

2 root  RT   0 000 S  0.0  0.0   0:05.75 migration/0

3 root  34  19 000 S  0.0  0.0   5:22.97 ksoftirqd/0

4 root  RT   0 000 S  0.0  0.0   0:07.90 migration/1

5 root  34  19 000 S  0.0  0.0   0:00.27 ksoftirqd/1

6 root  RT   0 000 S  0.0  0.0   0:04.07 migration/2

7 root  34  19 000 S  0.0  0.0   0:00.47 ksoftirqd/2

8 root  RT   0 000 S  0.0  0.0   0:04.00 migration/3

9 root  34  19 000 S  0.0  0.0   0:00.33 ksoftirqd/3

2、通过TOP -H -p 进程ID,找到具体的线程占用情况,Shift+H可以开启关闭线程显示

$ top -H -p 24714

top - 20:15:30 up 850 days,  1:22,  3 users,  load average: 1.26, 1.09, 1.02

Tasks:  16 total,   1 running,  15 sleeping,   0 stopped,   0 zombie

Cpu(s): 24.8% us,  0.3% sy,  0.0% ni, 73.1% id,  0.0% wa,  0.0% hi,  1.8% si

Mem:  16418172k total, 15701376k used,   716796k free,  1146704k buffers

Swap: 10223608k total,0k used, 10223608k free, 12546048k cached

PID USER  PR  NI  VIRT  RES  SHR S %CPU %MEMTIME+  COMMAND

24729 ztgame16   0 1409m 1.2g 4252 R 97.0  7.4   2307:22 IMVChannelServe

24721 ztgame15   0 1409m 1.2g 4252 S  2.0  7.4  84:22.40 IMVChannelServe

24714 ztgame16   0 1409m 1.2g 4252 S  0.0  7.4   0:03.80 IMVChannelServe

24716 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe

24717 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.04 IMVChannelServe

24718 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe

24719 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.08 IMVChannelServe

24720 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe

24722 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe

24723 ztgame16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe

24724 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe

24725 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:09.83 IMVChannelServe

24726 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe

24727 ztgame15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.76 IMVChannelServe

24728 ztgame16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.53 IMVChannelServe

24730 ztgame16   0 1409m 1.2g 4252 S  0.0  7.4   2:42.18 IMVChannelServe

3、通过命令pstack 进程ID显示线程堆栈,LWP 24729对应线程ID的堆栈,就是占用CPU最高的堆栈,可以具体分析什么原因造成的。

$ pstack 24714

Thread 16 (Thread 1084229984 (LWP 24716)):

#0  0x00000039c5a901d5 in __nanosleep_nocancel () from /lib64/tls/libc.so.6

#1  0x00000039c5ac3058 in usleep () from /lib64/tls/libc.so.6

#2  0x00000000005ebe10 in zVerifyThread::run ()

#3  0x00000000005e9d29 in zThread::threadFunc ()

#4  0x00000039c6106137 in start_thread () from /lib64/tls/libpthread.so.0

#5  0x00000039c5ac9883 in clone () from /lib64/tls/libc.so.6

Thread 15 (Thread 1094719840 (LWP 24717)):

#0  0x00000039c5a901d5 in __nanosleep_nocancel () from /lib64/tls/libc.so.6

#1  0x00000039c5ac3058 in usleep () from /lib64/tls/libc.so.6

#2  0x00000000005ebe10 in zVerifyThread::run ()

#3  0x00000000005e9d29 in zThread::threadFunc ()

#4  0x00000039c6106137 in start_thread () from /lib64/tls/libpthread.so.0

#5  0x00000039c5ac9883 in clone () from /lib64/tls/libc.so.6

Thread 14 (Thread 1105209696 (LWP 24718)):

#0  0x00000039c5a901d5 in __nanosleep_nocancel () from /lib64/tls/libc.so.6

#1  0x00000039c5ac3058 in usleep () from /lib64/tls/libc.so.6

#2  0x00000000005ebe10 in zVerifyThread::run ()

#3  0x00000000005e9d29 in zThread::threadFunc ()

#4  0x00000039c6106137 in start_thread () from /lib64/tls/libpthread.so.0

#5  0x00000039c5ac9883 in clone () from /lib64/tls/libc.so.6

Thread 13 (Thread 1115699552 (LWP 24719)):

#0  0x00000039c5a901d5 in __nanosleep_nocancel () from /lib64/tls/libc.so.6

#1  0x00000039c5ac3058 in usleep () from /lib64/tls/libc.so.6

#2  0x00000000005ebe10 in zVerifyThread::run ()

#3  0x00000000005e9d29 in zThread::threadFunc ()

#4  0x00000039c6106137 in start_thread () from /lib64/tls/libpthread.so.0

#5  0x00000039c5ac9883 in clone () from /lib64/tls/libc.so.6

Thread 3 (Thread 1220598112 (LWP 24729)):

#0  0x00000039c5a71e87 in memset () from /lib64/tls/libc.so.6

#1  0x00000000004fa591 in ChannelTask::forwardToClientByMedia ()

#2  0x0000000000506220 in ChannelTask::parseClientMsg_Normal ()

#3  0x000000000051ef55 in ChannelTask::parseClientMsg ()

#4  0x000000000051f070 in ChannelTask::cmdMsgParse_Forward ()

#5  0x000000000051f1d1 in ChannelTask::cmdMsgParse ()

#6  0x000000000051f414 in ChannelTask::processCmd ()

#7  0x0000000000523ea8 in ChannelTaskManager::processCmd ()

#8  0x0000000000525ddd in ChannelTimeTick::run ()

#9  0x00000000005e9d29 in zThread::threadFunc ()

#10 0x00000039c6106137 in start_thread () from /lib64/tls/libpthread.so.0

#11 0x00000039c5ac9883 in clone () from /lib64/tls/libc.so.6

Thread 2 (Thread 1231087968 (LWP 24730)):

#0  0x00000039c610af8b in __lll_mutex_lock_wait ()

#1  0x0000000000000001 in ?? ()

#2  0x0000000000000065 in ?? ()

#3  0x00000039c6107d87 in pthread_mutex_lock () from /lib64/tls/libpthread.so.0

#4  0x0000003a500ae29e in operator delete () from /usr/lib64/libstdc++.so.6

#5  0x000000000053f59d in ChannelLoadClient::processCmd_DB ()

#6  0x00000000005986c9 in GameAppClient::processTaskCmd_DB ()

#7  0x00000039c5a901e3 in __nanosleep_nocancel () from /lib64/tls/libc.so.6

#8  0x0000000000000000 in ?? ()

Thread 1 (Thread 182894183104 (LWP 24714)):

#0  0x00000039c5ac9c5c in epoll_wait () from /lib64/tls/libc.so.6

#1  0x0000000000620cac in zTCPServer::accept ()

#2  0x00000000005f9c0d in zNetService::serviceCallback ()

#3  0x00000000005f89e3 in zService::main ()

#4  0x0000000000564298 in main ()

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容