找出进程占用cpu高的原因。

进程占用cpu高,一般是由于进程长时间占用cpu,又没有主动释放占用。如果想主动释放cpu,可以调用sleep。在写程序的时候,尤其要注意while 等循环的地方。

找出php进程在执行那段代码

$sudo gdb -p 10434
(gdb) print (char *)executor_globals.active_op_array->filename
$13 = 0x2924118 "/home/admin/gearman_manager/pecl-manager.php"
(gdb) print executor_globals->current_execute_data->opline->lineno
$14 = 55
(gdb) c
Continuing.
^C
Program received signal SIGINT, Interrupt.
0x00000031d32306d0 in sigprocmask () from /lib64/libc.so.6
(gdb) print executor_globals->current_execute_data->opline->lineno
$15 = 71
(gdb) c
Continuing.
^C
Program received signal SIGINT, Interrupt.
0x00000000006250e1 in zend_hash_find ()
(gdb) print executor_globals->current_execute_data->opline->lineno
$16 = 53

如果对上面的命令有疑问,可以查看 当cpu飙升时,找出php中可能有问题的代码行
根据上面的信息,我们可以知道,cpu高时,正在执行/home/admin/gearman_manager/pecl-manager.php文件。并且正在执行53和71行附近的代码。

还可以通过strace进行调试

最新文章

  1. HTML5 -入门 (---css样式-------------(css基础与css选择器)---------------------—)
  2. CSS 伪类 (Pseudo-classes)
  3. uploadify 自动访问url 初始化 自动请求
  4. debian7.1 sources.list
  5. Unix/Linux 命令技巧
  6. context switches per second 上下文切换
  7. 转: javaWeb学习总结(见过最好的知识合集,相当给力,强烈推荐)
  8. 明晰三种常见存储技术:DAS、SAN和NAS
  9. HDU 4946 Area of Mushroom 凸包 第八次多校
  10. Apple 内购
  11. Spring 进入Controller前参数校验
  12. PAT1001A+B Format
  13. UE4行为树
  14. 两个python安装模块后 ImportError: No module named
  15. C语言实现Winsocket网络传输数据时乱码问题
  16. Maven介绍及安装与配置
  17. 【SVD、特征值分解、PCA关系】
  18. maven中scope标签详解
  19. beautifulsoup4 安装教程
  20. 【API设计】RESTful API 设计指南

热门文章

  1. T-SQL利用Case When Then多条件判断
  2. w3c与微软(IE)事件注册区别 -Tom
  3. 手动导出Excel方法
  4. Python中的__new__()方法的使用
  5. boost中的智能指针
  6. Android AIDL Service
  7. centos JDK安装
  8. Struts2的Action中如何操作作用域对象
  9. Hbase之插入数据
  10. JDK环境变量安装正确还报错的情况解决方案