发现问题

最近,发现发现服务器不稳定,有些服务经常死掉,查看内存,发现内存消耗过多,经多方查询,最终解决,过程记录如下。

分析问题

发现问题以后,首先使用free -m指令查看当前服务器执行状况:

linux bioset进程 太多 linux进程过多_linux bioset进程 太多

可以看到我的服务器内存是2G的,但是目前可用内存只剩下70M,内存使用率高达92%,很有可能是内存使用率过高导致数据库服务挂断。

继续看详细情况,使用top指令:

linux bioset进程 太多 linux进程过多_数据库_02

然后再看指令输出结果中详细列出的进程情况,重点关注第10列内存使用占比:

linux bioset进程 太多 linux进程过多_服务器_03

发现CPU使用率不算高,也排除了CPU的问题,另外可以看到数据库服务占用15.2%的内存,内存使用过高时将会挤掉数据库进程(占用内存最高的进程),导致服务挂断,所以我们需要查看详细内存使用情况,是哪些进程耗费了这么多的内存呢?

使用指令:

psauxw|head -1;psauxw|sort -rn -k4|head -40

查看消耗内存最多的前40个进程:

linux bioset进程 太多 linux进程过多_服务器_04

解决问题

通过搜索,发现可以通过配置pm.max_children属性,控制php-fpm子进程数量,首先,打开php-fpm配置文件,执行指令:

vi/etc/php-fpm.d/www.conf

找到pm.max_children字段,发现其值过大:

linux bioset进程 太多 linux进程过多_数据库_05

如图,pm.max_children值为50,每一个进程占用1%-2.5%的内存,加起来就耗费大半内存了,所以我们需要将其值调小,本人这里将其设置为35,同时,检查以下两个属性:

pm.max_spare_servers: 该值表示保证空闲进程数最大值,如果空闲进程大于此值,此进行清理

pm.min_spare_servers: 保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程;

这两个值均不能不能大于pm.max_children值,通常设置pm.max_spare_servers值为pm.max_children值的60%-80%。

最后,重启php-fpm

service php-fpm restart

再次查看内存使用情况, 使用内存降低很多:

linux bioset进程 太多 linux进程过多_linux进程太大占用内存_06

之后经过多次观察内存使用情况,发现此次改进后,服务器内存资源消耗得到很大缓解。