Linux下找出CPU过高的线程

确定是CPU过高

使用top观察是否存在CPU使用率过高现象

找出线程

对CPU使用率过高的进程的所有线程进行排序

ps H -e -o pid,tid,pcpu,cmd --sort=pcpu |grep xxx得到如下结果,其中线程2909使用了7.8%的CPU. 2907 2913 0.0 ./xxx 2907 2909 7.8 ./xxx也可以通过查看/proc中的信息来确定高CPU线程. 打印了4列,线程ID,线程名,用户时间和内核时间(排名未分先后) awk '{print $1,$2,$14,$15}' /proc/2907/task/*/stat

找出调用栈

使用gdb attach nmsagent所在的进程,在gdb中使用 info threads显示所有线程

gdb

gdb>attach 2907

gdb>info threads

得到如下结果,可以发现2909线程的编号是12

  13 Thread 0xad5f2b70 (LWP 2908)  0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1

  12 Thread 0xad58eb70 (LWP 2909)  0x006e0422 in __kernel_vsyscall ()

  11 Thread 0xad52ab70 (LWP 2910)  0x006e0422 in __kernel_vsyscall ()

  10 Thread 0xad4f8b70 (LWP 2911)  0x006e0422 in __kernel_vsyscall ()

  9 Thread 0xad4c6b70 (LWP 2912)  0x006e0422 in __kernel_vsyscall ()

  8 Thread 0xad3feb70 (LWP 2913)  0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1

  7 Thread 0xace08b70 (LWP 2914)  0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1

  6 Thread 0xac607b70 (LWP 2915)  0x006e0422 in __kernel_vsyscall ()

  5 Thread 0xac5e6b70 (LWP 2916)  0x006e0422 in __kernel_vsyscall ()

  4 Thread 0xac361b70 (LWP 2917)  0x006e0422 in __kernel_vsyscall ()

  3 Thread 0xac2fdb70 (LWP 2918)  0x006e0422 in __kernel_vsyscall ()

  2 Thread 0xac1fcb70 (LWP 2919)  0x004ef0d7 in mq_timedreceive () from /lib/tls/i686/cmov/librt.so.1

* 1 Thread 0xb78496d0 (LWP 2907)  0x006e0422 in __kernel_vsyscall ()

使用thread 切换线程,使用bt显示线程栈

gdb>thread 12

gdb>bt

得到如下线程栈

#0  0x006e0422 in __kernel_vsyscall ()

#1  0x001cca26 in nanosleep () from /lib/tls/i686/cmov/libc.so.6

#2  0x001fc2dc in usleep () from /lib/tls/i686/cmov/libc.so.6

#3  0x0806b510 in OspTaskDelay ()

#4  0x0805c710 in CDispatchTask::NodeMsgSendToSock() ()

#5  0x0805cc74 in DispatchTaskEntry ()

#6  0x0806a8e9 in OspTaskTemplateFunc(void*) ()

#7  0x00d4780e in start_thread () from /lib/tls/i686/cmov/libpthread.so.0

 #8  0x002027ee in clone () from /lib/tls/i686/cmov/libc.so.6

 ps + strace

得到进程ID 21465

ps -e |grep cmu

 4996 ?        00:00:25 cmu_fjga_sp3

21465 pts/5    00:08:10 cmu

得到线程时间, 其中最占CPU的是 EpollRecvTask 21581

ps -eL |grep 21465 21465 21579 pts/5 00:00:00 CamApp 21465 21580 pts/5 00:00:00 TimerMan Task 21465 21581 pts/5 00:09:02 EpollRecvTask 21465 21582 pts/5 00:00:00 使用 strace -p 21581 得到线程栈

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要定位Linux命令行中的内存泄漏和CPU过高线程和具体代码,您可以使用以下工具: 1. top: top 命令可以实时显示系统的 CPU 使用率、内存使用率、进程数量等信息,并按 CPU 使用率排序。您可以使用 top 命令来查找 CPU 占用过高的进程,并找出其进程 ID。 2. ps: ps 命令可以显示系统中正在运行的进程的详细信息。使用 ps 命令时,您可以通过 -eo 参数来选择需要显示的进程信息,例如进程 ID、CPU 占用率、内存使用量等。您可以使用 ps 命令来查找特定进程的详细信息,例如其线程 ID、进程状态等。 3. pmap: pmap 命令可以显示进程的内存映射。使用 pmap 命令时,您可以通过 -x 参数来显示详细信息,例如内存占用量、内存映射地址等。您可以使用 pmap 命令来查找进程的内存占用情况,以判断是否存在内存泄漏。 4. strace: strace 命令可以跟踪进程执行的系统调用,以及调用的结果和参数。使用 strace 命令时,您可以通过 -p 参数来指定需要跟踪的进程 ID。您可以使用 strace 命令来查找进程执行的具体代码,以判断是否存在 CPU 占用过高的问题。 5. perf: perf 命令可以提供系统和进程的性能分析信息。使用 perf 命令时,您可以通过 record 子命令来记录进程执行的函数调用栈信息。然后,使用 report 子命令来查看记录的性能信息。您可以使用 perf 命令来查找进程执行的具体代码,并进行性能分析。 总之,要定位Linux命令行中的内存泄漏和CPU过高线程和具体代码,您需要综合使用以上工具来进行系统和进程的监控、跟踪、性能分析等工作,以便找出问题所在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值