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

简介: 1、TOP命令,找到占用CPU最高的进程 $ top top - 20:11:45 up 850 days,  1:18,  3 users,  load average: 1.04, 1.01, 0.

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 ()


本文永久更新地址:http://www.linuxdiyf.com/linux/18227.html

目录
相关文章
|
19天前
|
Java 开发者
如何通过易语言多线程提升程序响应速度
如何通过易语言多线程提升程序响应速度
116 62
|
4天前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
26 4
linux进程管理万字详解!!!
|
3天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
24 4
|
4天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
6天前
|
消息中间件 存储 Linux
|
12天前
|
Java 开发者
如何通过易语言多线程提升程序响应速度?
如何通过易语言多线程提升程序响应速度?
|
12天前
|
运维 Linux
Linux查找占用的端口,并杀死进程的简单方法
通过上述步骤和命令,您能够迅速识别并根据实际情况管理Linux系统中占用特定端口的进程。为了获得更全面的服务器管理技巧和解决方案,提供了丰富的资源和专业服务,是您提升运维技能的理想选择。
12 1
|
24天前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
【10月更文挑战第9天】本文将深入浅出地介绍Linux系统中的进程管理机制,包括进程的概念、状态、调度以及如何在Linux环境下进行进程控制。我们将通过直观的语言和生动的比喻,让读者轻松掌握这一核心概念。文章不仅适合初学者构建基础,也能帮助有经验的用户加深对进程管理的理解。
18 1
|
19天前
|
监控 Java API
|
8天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
151 1