后台服务器CPU使用率高 问题分析方法

 

一、找出cpu使用率高的进程和线程:

 

a、将 cpu 占用率高的线程找出来:

ps H -eo user,pid,ppid,tid,time,%cpu,cmd--sort=%cpu

 

b、对于多线程的服务,通过top命令得到cpu使用率高的进程后,可以使用如下命令查看该进程下各线程cpu使用率

ps -eLo pid,lwp,pcpu | grep PID

 

c、直接使用 ps Hh -eopid,tid,pcpu | sort -nk3 |tail 获取对于的进程号和线程号

 

 

二、gdb调试cpu使用率高的进程:

 

对于单线程的程序,比较好查,这里只说一下多线程的调试方法

 

GDB多线程调试的基本命令

info threads显示当前可调试的所有线程,每个线程会有一个GDB为其分配的ID,后面操作线程的时候会用到这个ID。前面有*的是当前调试的线程。

thread ID 切换当前调试的线程为指定ID的线程。

break thread_test.c:123 thread all 在所有线程中相应的行上设置断点

thread apply ID1 ID2 command 让一个或者多个线程执行GDB命令command。 

thread apply all command 让所有被调试线程执行GDB命令command。

setscheduler-locking off|on|step :

估计是实际使用过多线程调试的人都可以发现,在使用step或者continue命令调试当前被调试线程的时候,其他线程也是同时执行的,怎么只让被调试程序执行呢?通过这个命令就可以实现这个需求。

 

off 不锁定任何线程,也就是所有线程都执行,这是默认值。

on 只有当前被调试程序会执行。

step 在单步的时候,除了next过一个函数的情况(熟悉情况的人可能知道,这其实是一个设置断点然后continue的行为)以外,只有当前线程会执行。

 

 

gdb查看线程信息及切换线程:

info threads     查看当前进程所有线程

thread 4            切换到线程4

backtrace                   查看当前函数调用栈

一般情况下多线程的时候,由于是同时运行的,最好设置 set scheduler-locking on

这样的话,只调试当前线程 。

 

三、查看线程栈

gstack pid

你可能感兴趣的:(后台服务器CPU使用率高 问题分析方法)