码迷,mamicode.com
首页 > Web开发 > 详细

记录一次php占用系统资源过高的问题

时间:2018-01-18 17:08:23      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:tle   本地服务器   tps   class   web   对比   服务   process   sha   

本地环境:redhat6.7系统。 nginx1.12.1 ,php7.1.0,  代码使用yii2框架

问题:本地的web站需要用到elasticsearch服务。当php使用本地服务器搭建的elasticsearch时,本地的负载都是正常。 当我使用aws 的elasticsearch service服务时,本地服务器出现负载经常过高的情况。查看nginx 和php日志,发现没有异常。系统的并发连接数也不高。这时候想到我们老大给我讲的一个strace诊断工具。


调试过程:

  1. 查找一个php的子进程id

  2. strace -cp pid 跟踪进程的调用

系统当时的负载:

技术分享图片

strace 调试过程

技术分享图片


这边就发现php调用elasticsearch的时候,会去本地找一个文件,这个文件是不存在的。从而导致服务器负载偏高。通过对比aws elasticsearch 和本地es 集群的区别。发现只有调用的方法不一样。代码里面是用https的方法调用的,所以他会去本地找这个证书库文件。我立即联系开发,把调用方式改成http之后,观察一段时间,服务器负载恢复正常了。

strace -T -e access -p 1379

技术分享图片


记录一次php占用系统资源过高的问题

标签:tle   本地服务器   tps   class   web   对比   服务   process   sha   

原文地址:http://blog.51cto.com/thedream/2062509

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!