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

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

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


调试过程:web

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

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

系统当时的负载:php7

TIM图片20180118160932.png

strace 调试过程并发

TIM图片20180118161427.png


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

strace -T -e access -p 1379yii

TIM图片20180118161659.png

相关文章
相关标签/搜索