php守护进程占用内存很高,如何排查问题出在哪?

问题描述

用PHP程序写了一个守护进程,占用内存特别高(%MEM:80%),且不释放。

我只能定位到这个进程的PID,但是我无法定位到是程序的哪块代码引起的,如何才能查到问题出在哪呢?

前提条件不变:
- 即用PHP程序运行的守护进程。
- 我已在程序中手动释放了内存。
阅读 3.4k
2 个回答

如果不嫌麻烦的话,可以试试我的php-stacktrace,不需扩展,不需要重启进程,只要一个PID,就可以读取PHP进程的内存,解析出调用堆栈信息,从而知道PHP进程在干啥了。

间隔几十ms调用一次,把结果保存起来,就是个采样profiler:)

看错题目,原来是内存问题,可以直接生用gdb dump内存然后慢慢查。

代码块不多的话,多用 memory_get_usage 打印当前内存占用。
php守护进程一般都会出现泄漏问题,很多情况下是扩展导致的。
所以生产环境建议每执行一条任务,计数器+1,当超过一定量,比如100,退出进程,保证业务逻辑完整执行(自己退出就会完整执行,被系统干掉就可能没执行完)
然后使用nodejs的pm2进程保活

pm2配置文件例子:

{
  "name": "显示名称",
  "script": "cli.php",
  "exec_interpreter": "php",
  "exec_mode": "fork",
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题