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