当我的博客数据库服务常常忽然挂断,形成没法访问时咱们能作什么?本篇主题就是记录博主针对这一现象时发现问题,分析问题,最后解决问题的过程。php
欢迎访问个人我的博客mysql
最近,发现我的博客的Linux服务器,数据库服务常常挂掉,致使须要重启,才能正常访问,极其恶心,因而决心开始解决问题,解放个人时间和精力(我可不想常常出问题,而后人工重启,费力费时)。linux
发现问题之后,首先使用free -m
指令查看当前服务器执行情况:sql
能够看到个人服务器内存是2G的,可是目前可用内存只剩下70M,内存使用率高达92%,颇有多是内存使用率太高致使数据库服务挂断。shell
继续看详细状况,使用top
指令:数据库
而后再看指令输出结果中详细列出的进程状况,重点关注第10列内存使用占比:bash
发现CPU使用率不算高,也排除了CPU的问题,另外能够看到数据库服务占用15.2%的内存,内存使用太高时将会挤掉数据库进程(占用内存最高的进程),致使服务挂断,因此咱们须要查看详细内存使用状况,是哪些进程耗费了这么多的内存呢?服务器
使用指令:php-fpm
ps auxw|head -1;ps auxw|sort -rn -k4|head -40复制代码
查看消耗内存最多的前40个进程:spa
查看第四列内存使用占比,发现除了mysql数据库服务以外,php-fpm服务池开启了太多子进程,占用超过大半内存,问题找到了,咱们开始解决问题:设置控制php-fpm进程池进程数量。
经过各类搜索手段,发现能够经过配置pm.max_children
属性,控制php-fpm子进程数量,首先,打开php-fpm配置文件,执行指令:
vi /etc/php-fpm.d/www.conf复制代码
找到pm.max_children
字段,发现其值过大:
如图,pm.max_children
值为50,每个进程占用1%-2.5%的内存,加起来就耗费大半内存了,因此咱们须要将其值调小,博主这里将其设置为25,同时,检查如下两个属性:
pm.max_spare_servers
: 该值表示保证空闲进程数最大值,若是空闲进程大于此值,此进行清理pm.min_spare_servers
: 保证空闲进程数最小值,若是空闲进程小于此值,则建立新的子进程;这两个值均不能不能大于pm.max_children
值,一般设置pm.max_spare_servers
值为pm.max_children
值的60%-80%。
最后,重启php-fpm
systemctl restart php-fpm复制代码
再次查看内存使用状况, 使用内存下降不少:
以后通过屡次观察内存使用状况,发现这次改进后,服务器内存资源消耗获得很大缓解。