后台服务器CPU使用率高 问题分析方法
来源:互联网 发布:澳洲留学体验 知乎 编辑:程序博客网 时间:2024/06/05 07:52
一、找出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使用率高 问题分析方法
- cpu使用率高问题
- CPU使用率高报警分析
- linux cpu 使用率比较高问题调试
- 定位高cpu使用率
- cpu高分析方法
- Java 占用CPU使用率很高的分析
- Java 占用CPU使用率很高的分析
- Java 占用CPU使用率很高的分析 .
- Java 占用CPU使用率很高的分析
- Mysql数据库服务器CPU冲高问题定位及分析
- 双缓冲绘图,解决cpu使用率高问题
- websphere服务器cpu使用率较高原因定位分析
- websphere服务器cpu使用率较高原因定位分析
- websphere服务器cpu使用率较高原因定位分析
- CPU使用率低 内存使用率高
- 如何解决服务器CPU使用率过高的问题<一>
- 如何解决服务器CPU使用率过高的问题<二>
- mysql的distinct用法-mysql中如何筛选出非重复的数据
- 面向对象中接口和抽象类的区别
- Socket进程通信机制
- Android 混淆 Unknown verification type
- android 通过php post 向mysql数据库写入数据
- 后台服务器CPU使用率高 问题分析方法
- Java线程:线程的调度-休眠
- LaTeX-02 文档基本结构、编译、特殊符号输出
- HTML5网页设计初窥系列课程
- Linux内核态和用户态的区别
- File类的学习
- UVa #1152 4 Values whose Sum is 0 (例题8-3)
- Android 如何获取 umeng 的 渠道信息
- CUDA, 软件抽象的幻影背后 之三