php守护进程占用内存很高,如何排查问题出在哪?
问题描述
用PHP程序写了一个守护进程,占用内存特别高(%MEM:80%),且不释放。
我只能定位到这个进程的PID,但是我无法定位到是程序的哪块代码引起的,如何才能查到问题出在哪呢?
前提条件不变:
- 即用PHP程序运行的守护进程。
- 我已在程序中手动释放了内存。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
如果不嫌麻烦的话,可以试试我的php-stacktrace,不需扩展,不需要重启进程,只要一个PID,就可以读取PHP进程的内存,解析出调用堆栈信息,从而知道PHP进程在干啥了。
间隔几十ms调用一次,把结果保存起来,就是个采样profiler:)
看错题目,原来是内存问题,可以直接生用gdb dump内存然后慢慢查。
代码块不多的话,多用
memory_get_usage
打印当前内存占用。php守护进程一般都会出现泄漏问题,很多情况下是扩展导致的。
所以生产环境建议每执行一条任务,计数器+1,当超过一定量,比如100,退出进程,保证业务逻辑完整执行(自己退出就会完整执行,被系统干掉就可能没执行完)
然后使用nodejs的
pm2
进程保活pm2配置文件例子: