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

简介:

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


[plain] view plain copy

  1. $ top  

  2.   

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

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

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

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

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

  8.   

  9.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                  

  10. 24714 ztgame    16   0 1409m 1.2g 4252 S 99.6  7.4   2390:57 IMVChannelServe                                                          

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

  12.     2 root      RT   0     0    0    0 S  0.0  0.0   0:05.75 migration/0                                                              

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

  14.     4 root      RT   0     0    0    0 S  0.0  0.0   0:07.90 migration/1                                                              

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

  16.     6 root      RT   0     0    0    0 S  0.0  0.0   0:04.07 migration/2                                                              

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

  18.     8 root      RT   0     0    0    0 S  0.0  0.0   0:04.00 migration/3                                                              

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



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


[plain] view plain copy

  1. $ top -H -p 24714  

  2.   

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

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

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

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

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

  8.   

  9.   PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                  

  10. 24729 ztgame    16   0 1409m 1.2g 4252 R 97.0  7.4   2307:22 IMVChannelServe                                                          

  11. 24721 ztgame    15   0 1409m 1.2g 4252 S  2.0  7.4  84:22.40 IMVChannelServe                                                          

  12. 24714 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:03.80 IMVChannelServe                                                          

  13. 24716 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe                                                          

  14. 24717 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.04 IMVChannelServe                                                          

  15. 24718 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe                                                          

  16. 24719 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.08 IMVChannelServe                                                          

  17. 24720 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe                                                          

  18. 24722 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe                                                          

  19. 24723 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe                                                          

  20. 24724 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe                                                          

  21. 24725 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:09.83 IMVChannelServe                                                          

  22. 24726 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe                                                          

  23. 24727 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.76 IMVChannelServe                                                          

  24. 24728 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.53 IMVChannelServe                                                          

  25. 24730 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   2:42.18 IMVChannelServe                                                          


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



[plain] view plain copy

  1. $ pstack 24714  

  2. Thread 16 (Thread 1084229984 (LWP 24716)):  

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

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

  5. #2  0x00000000005ebe10 in zVerifyThread::run ()  

  6. #3  0x00000000005e9d29 in zThread::threadFunc ()  

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

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

  9. Thread 15 (Thread 1094719840 (LWP 24717)):  

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

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

  12. #2  0x00000000005ebe10 in zVerifyThread::run ()  

  13. #3  0x00000000005e9d29 in zThread::threadFunc ()  

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

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

  16. Thread 14 (Thread 1105209696 (LWP 24718)):  

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

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

  19. #2  0x00000000005ebe10 in zVerifyThread::run ()  

  20. #3  0x00000000005e9d29 in zThread::threadFunc ()  

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

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

  23. Thread 13 (Thread 1115699552 (LWP 24719)):  

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

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

  26. #2  0x00000000005ebe10 in zVerifyThread::run ()  

  27. #3  0x00000000005e9d29 in zThread::threadFunc ()  

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

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

  30. Thread 3 (Thread 1220598112 (LWP 24729)):  

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

  32. #1  0x00000000004fa591 in ChannelTask::forwardToClientByMedia ()  

  33. #2  0x0000000000506220 in ChannelTask::parseClientMsg_Normal ()  

  34. #3  0x000000000051ef55 in ChannelTask::parseClientMsg ()  

  35. #4  0x000000000051f070 in ChannelTask::cmdMsgParse_Forward ()  

  36. #5  0x000000000051f1d1 in ChannelTask::cmdMsgParse ()  

  37. #6  0x000000000051f414 in ChannelTask::processCmd ()  

  38. #7  0x0000000000523ea8 in ChannelTaskManager::processCmd ()  

  39. #8  0x0000000000525ddd in ChannelTimeTick::run ()  

  40. #9  0x00000000005e9d29 in zThread::threadFunc ()  

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

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

  43. Thread 2 (Thread 1231087968 (LWP 24730)):  

  44. #0  0x00000039c610af8b in __lll_mutex_lock_wait ()  

  45. #1  0x0000000000000001 in ?? ()  

  46. #2  0x0000000000000065 in ?? ()  

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

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

  49. #5  0x000000000053f59d in ChannelLoadClient::processCmd_DB ()  

  50. #6  0x00000000005986c9 in GameAppClient::processTaskCmd_DB ()  

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

  52. #8  0x0000000000000000 in ?? ()  

  53. Thread 1 (Thread 182894183104 (LWP 24714)):  

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

  55. #1  0x0000000000620cac in zTCPServer::accept ()  

  56. #2  0x00000000005f9c0d in zNetService::serviceCallback ()  

  57. #3  0x00000000005f89e3 in zService::main ()  

  58. #4  0x0000000000564298 in main ()  










本文转自 chengxuyonghu 51CTO博客,原文链接:http://blog.51cto.com/6226001001/1743448,如需转载请自行联系原作者
目录
相关文章
|
17天前
|
消息中间件 并行计算 安全
进程、线程、协程
【10月更文挑战第16天】进程、线程和协程是计算机程序执行的三种基本形式。进程是操作系统资源分配和调度的基本单位,具有独立的内存空间,稳定性高但资源消耗大。线程是进程内的执行单元,共享内存,轻量级且并发性好,但同步复杂。协程是用户态的轻量级调度单位,适用于高并发和IO密集型任务,资源消耗最小,但不支持多核并行。
35 1
|
30天前
线程CPU异常定位分析
【10月更文挑战第3天】 开发过程中会出现一些CPU异常升高的问题,想要定位到具体的位置就需要一系列的分析,记录一些分析手段。
53 0
|
1天前
|
Linux 调度 C语言
深入理解操作系统:进程和线程的管理
【10月更文挑战第32天】本文旨在通过浅显易懂的语言和实际代码示例,带领读者探索操作系统中进程与线程的奥秘。我们将从基础知识出发,逐步深入到它们在操作系统中的实现和管理机制,最终通过实践加深对这一核心概念的理解。无论你是编程新手还是希望复习相关知识的资深开发者,这篇文章都将为你提供有价值的见解。
|
3天前
深入理解操作系统:进程与线程的管理
【10月更文挑战第30天】操作系统是计算机系统的核心,它负责管理计算机硬件资源,为应用程序提供基础服务。本文将深入探讨操作系统中进程和线程的概念、区别以及它们在资源管理中的作用。通过本文的学习,读者将能够更好地理解操作系统的工作原理,并掌握进程和线程的管理技巧。
13 2
|
5天前
|
调度 Python
深入浅出操作系统:进程与线程的奥秘
【10月更文挑战第28天】在数字世界的幕后,操作系统悄无声息地扮演着关键角色。本文将拨开迷雾,深入探讨操作系统中的两个基本概念——进程和线程。我们将通过生动的比喻和直观的解释,揭示它们之间的差异与联系,并展示如何在实际应用中灵活运用这些知识。准备好了吗?让我们开始这段揭秘之旅!
|
29天前
|
存储 消息中间件 人工智能
进程,线程,协程 - 你了解多少?
本故事采用简洁明了的对话方式,尽洪荒之力让你在轻松无负担的氛围中,稍微深入地理解进程、线程和协程的相关原理知识
40 2
进程,线程,协程 - 你了解多少?
|
15天前
|
Python
Python中的多线程与多进程
本文将探讨Python中多线程和多进程的基本概念、使用场景以及实现方式。通过对比分析,我们将了解何时使用多线程或多进程更为合适,并提供一些实用的代码示例来帮助读者更好地理解这两种并发编程技术。
|
18天前
|
消息中间件 并行计算 安全
进程、线程、协程
【10月更文挑战第15天】进程、线程和协程是操作系统中三种不同的执行单元。进程是资源分配和调度的基本单位,每个进程有独立的内存空间;线程是进程内的执行路径,共享进程资源,切换成本较低;协程则更轻量,由用户态调度,适合处理高并发和IO密集型任务。进程提供高隔离性和安全性,线程支持高并发,协程则在资源消耗和调度灵活性方面表现优异。
42 2
|
2月前
|
存储 消息中间件 资源调度
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
该文章总结了操作系统基础知识中的十个关键知识点,涵盖了进程与线程的概念及区别、进程间通信方式、线程同步机制、死锁现象及其预防方法、进程状态等内容,并通过具体实例帮助理解这些概念。
「offer来了」进程线程有啥关系?10个知识点带你巩固操作系统基础知识
|
24天前
|
算法 安全 调度
深入理解操作系统:进程与线程的管理
【10月更文挑战第9天】在数字世界的心脏跳动着的,不是别的,正是操作系统。它如同一位无形的指挥家,协调着硬件与软件的和谐合作。本文将揭开操作系统中进程与线程管理的神秘面纱,通过浅显易懂的语言和生动的比喻,带你走进这一复杂而又精妙的世界。我们将从进程的诞生讲起,探索线程的微妙关系,直至深入内核,理解调度算法的智慧。让我们一起跟随代码的脚步,解锁操作系统的更多秘密。
33 1