linux apache占用内存过高,linux – 找出高CPU占用率的apache进程实际上在做什么?...

目前我们的服务器存在一些问题,间歇性地,我们似乎得到了运行和运行的apache进程,占用了100%的cpu.

在运行top时,我们会看到以下内容:

PID USER PR NI VIRT RES SHR S %cpu %MEM TIME+ COMMAND

20788 www-data 20 0 318m 18m 3984 R 100 0.0 40:29.21 /usr/sbin/apache2 -k start

23523 www-data 20 0 319m 20m 4684 R 100 0.0 4:12.36 /usr/sbin/apache2 -k start

我想尝试找出导致此问题的脚本(或其他任何内容),所以我尝试了:

strace -p 20788

但是根本没有显示任何输出(我已经离开它大约10分钟,它什么都没显示).根据我的理解,这可能意味着它陷入无限循环,并且没有任何“系统调用”显示.

还有什么我可以做的,以显示正在发生的事情?

谢谢

编辑 – 忘记提及,这是一个在任何时候都有几百个用户的实时服务器!所以我真的不能自由地尝试更改配置选项并重启apache.

编辑2 – 当没有使用–enable-debug配置PHP时,来自gdb的回溯(bt)似乎没那么有用 – 它只显示“execute()”,但我需要知道PHP脚本是什么实际上正在运行..还有其他方法吗?

#0 0x00007f6c143fb0c5 in ?? () from /usr/lib/apache2/modules/libPHP5.so

#1 0x00007f6c143b040b in execute () from /usr/lib/apache2/modules/libPHP5.so

#2 0x00007f6c1438b970 in zend_execute_scripts () from /usr/lib/apache2/modules/libPHP5.so

#3 0x00007f6c14337fe3 in PHP_execute_script () from /usr/lib/apache2/modules/libPHP5.so

#4 0x00007f6c1441ae7d in ?? () from /usr/lib/apache2/modules/libPHP5.so

#5 0x00007f6c18912508 in ap_run_handler ()

#6 0x00007f6c1891297e in ap_invoke_handler ()

#7 0x00007f6c18922570 in ap_process_request ()

#8 0x00007f6c1891f398 in ?? ()

#9 0x00007f6c18918fa8 in ap_run_process_connection ()

#10 0x00007f6c189271d0 in ?? ()

#11 0x00007f6c1892793a in ?? ()

#12 0x00007f6c189284e7 in ap_mpm_run ()

#13 0x00007f6c188fd4a4 in main ()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值