转自:http://blog.csdn.net/mergerly/article/details/47731305

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

[plain] view plaincopy
  1. $ top
  2. top - 20:11:45 up 850 days,  1:18,  3 users,  load average: 1.04, 1.01, 0.99
  3. Tasks:  61 total,   1 running,  60 sleeping,   0 stopped,   0 zombie
  4. Cpu(s):  1.4% us,  0.1% sy,  0.0% ni, 98.3% id,  0.1% wa,  0.0% hi,  0.2% si
  5. Mem:  16418172k total, 15693376k used,   724796k free,  1146696k buffers
  6. Swap: 10223608k total,        0k used, 10223608k free, 12537692k cached
  7. PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
  8. 24714 ztgame    16   0 1409m 1.2g 4252 S 99.6  7.4   2390:57 IMVChannelServe
  9. 1 root      16   0  4772  520  432 S  0.0  0.0   0:03.43 init
  10. 2 root      RT   0     0    0    0 S  0.0  0.0   0:05.75 migration/0
  11. 3 root      34  19     0    0    0 S  0.0  0.0   5:22.97 ksoftirqd/0
  12. 4 root      RT   0     0    0    0 S  0.0  0.0   0:07.90 migration/1
  13. 5 root      34  19     0    0    0 S  0.0  0.0   0:00.27 ksoftirqd/1
  14. 6 root      RT   0     0    0    0 S  0.0  0.0   0:04.07 migration/2
  15. 7 root      34  19     0    0    0 S  0.0  0.0   0:00.47 ksoftirqd/2
  16. 8 root      RT   0     0    0    0 S  0.0  0.0   0:04.00 migration/3
  17. 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 plaincopy
  1. $ top -H -p 24714
  2. top - 20:15:30 up 850 days,  1:22,  3 users,  load average: 1.26, 1.09, 1.02
  3. Tasks:  16 total,   1 running,  15 sleeping,   0 stopped,   0 zombie
  4. Cpu(s): 24.8% us,  0.3% sy,  0.0% ni, 73.1% id,  0.0% wa,  0.0% hi,  1.8% si
  5. Mem:  16418172k total, 15701376k used,   716796k free,  1146704k buffers
  6. Swap: 10223608k total,        0k used, 10223608k free, 12546048k cached
  7. PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
  8. 24729 ztgame    16   0 1409m 1.2g 4252 R 97.0  7.4   2307:22 IMVChannelServe
  9. 24721 ztgame    15   0 1409m 1.2g 4252 S  2.0  7.4  84:22.40 IMVChannelServe
  10. 24714 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:03.80 IMVChannelServe
  11. 24716 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe
  12. 24717 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.04 IMVChannelServe
  13. 24718 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe
  14. 24719 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.08 IMVChannelServe
  15. 24720 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe
  16. 24722 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe
  17. 24723 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe
  18. 24724 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.01 IMVChannelServe
  19. 24725 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:09.83 IMVChannelServe
  20. 24726 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.00 IMVChannelServe
  21. 24727 ztgame    15   0 1409m 1.2g 4252 S  0.0  7.4   0:00.76 IMVChannelServe
  22. 24728 ztgame    16   0 1409m 1.2g 4252 S  0.0  7.4   0:00.53 IMVChannelServe
  23. 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 plaincopy
  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 ()

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

  1. java进程cpu使用率高_什么会导致Java应用程序的CPU使用率飙升?

    问题 无限循环的while会导致CPU使用率飙升吗? 经常使用Young GC会导致CPU占用率飙升吗? 具有大量线程的应用程序的CPU使用率是否较高? CPU使用率高的应用程序的线程数是多少? 处于 ...

  2. linux ps内存占用率,linux ps命令,查看某进程cpu和内存占用率情况, linux ps命令,查看进程cpu和内存占用率排序。 不指定...

    背景:有时需要单看某个进程的CPU及占用情况,有时需要看整体进程的一个占用情况. 一. linux ps命令,查看某进程cpu和内存占用率情况 [root@test vhost]# ps aux US ...

  3. 【linux】cpu过高解决方法

    CPU过高情况: 1.使用top命令查看cpu的进程占用情况: 2.发现11443的进程占比过高,通过top -Hp 11443 查看线程的占用情况,发现11459.11460.11461线程的占比过 ...

  4. java进程CPU占用高如何排查-案例二

    近期项目新版本上线遇到cpu冲高现象,依据之前的经验,把这次排查过程记录下. 这次排查参考了之前记录的经验,还是很有用的:java进程cpu占用高如何排查_停5s的博客-CSDN博客_java进程cp ...

  5. 如何查看linux进程?

    如何查看linux进程? linux 下查看进程可以使用的命令: 1.ps命令查找与进程相关的PID号: 2.ps a 显示现行终端机下的所有程序,包括其他用户的程序. 3.ps -A 显示所有程序. ...

  6. linux查看java进程cpu占用过高

    linux下查找java进程占用CPU过高原因 1. 查找进程 top查看进程占用资源情况 明显看出java的两个进程22714,12406占用过高cpu.   2.查找线程 使用top -H -p ...

  7. linux杀掉cpu使用率高的进程,如何解决Linux中CPU使用率高的问题?

    电脑死机了?还是开始听到电脑发出很响的CPU风扇噪音?Linux中CPU使用率过高的原因很多,但最常见的原因是运行异常的应用程序.本文介绍了如何在Linux中解决CPU使用率过高的问题. 找出罪魁祸首 ...

  8. java进程CPU飙高

    早上某段时间突然看到看到一台生产机器上的CPU飙高 top 然后就请出了大神工具JVM 具体JVM的介绍看:http://www.cnblogs.com/smail-bao/p/6027756.htm ...

  9. linux进程cpu时间片,Linux性能监控之CPU篇

    这篇文章中,主要介绍CPU的一些基础知识. 首先介绍一下Linux kernel中的调度器(scheduler),调度器负责调度系统中的两种资源,一是线程,二是中断.调度器给不同资源不同的优先级.从高 ...

最新文章

  1. 数据架构简史:转换中的范式
  2. 汇编-理解call,ret
  3. 云场景实践研究第34期:加和科技
  4. UA MATH566 例题 Poisson回归、Overdispersion与负二项回归
  5. 使用基于注解的mybatis时,利用反射和注解生成sql语句
  6. Intel Realsense D435 Realsense View 错误 RT IC2 Config error
  7. 网易云助力云音乐短视频功能快速上线
  8. [译] 如何学习 CSS
  9. 青云QingCloud携手伟仕佳杰打造专业企业级云服务
  10. 多线程之wait和notify使用注意事项
  11. 第二篇:操纵MySQL数据库(2) - 基于ORM思想的SQLAlchemy库
  12. 阶段1 语言基础+高级_1-2 -面向对象和封装_1面向对象思想的概述
  13. python re 模块
  14. 基本数据类型与格式化输出
  15. SpringBoot+JSON+AJAX+ECharts+Fiddler实现前后端分离开发可视化(进阶篇)
  16. 【图像分割】基于matlab FCM侧扫声呐图像分割【含Matlab源码 1478期】
  17. 用excel表格解线性方程组
  18. 做事的态度与工作态度
  19. 计算机用什么命令调取共享记录,只需一串代码命令就可以获取你的电脑所有的无线网历史连接记录?...
  20. ENVI App Store

热门文章

  1. 如何正确选择仓储物流供应商?
  2. C#实现写入文本文件内容功能
  3. 微软IE 9 Beta全程体验图集
  4. Boostrap ZURB Foundation —— Web开发前端框架
  5. 想了好久 请多多指教
  6. Hive学习之路 (一)Hive初识
  7. UESTC 电子科大专题训练 DP-N
  8. sybase sp_procxmode简述
  9. delete在js里为引用删除
  10. 在线自动下载最新版本jquery