避免 php-fpm 耗尽内存导致宕机

服务器 struggling 3751次浏览 10个评论

php-fpm-error

今天早上又收到服务不可用的邮件,上次收到大约是一月前,一直很奇怪是什么原因导致的宕机,记得上次处理好像是重启了php-fpm就好了,今天登上服务器没有急着重启服务,还是一步步排除错误。

首先检查下个服务是否处于启动状态,由于我的 mysql 还是在另一台服务器上放着,用 ss -tln 命令查看后确认服务都处于正常开启状态,然后再看服务器的负载情况:

确认是不是由于负载过大而引起的,然而并不是,像我这种小站一般不会出现负载过大的情况。

继续查看是否由于内存耗尽或带宽限制等原因,用 free -m 查看后发现服务器的内存已经耗尽了:

before

继续查找内存耗尽的原因:

php-fpm-top

可以看出是由于 php-fpm 有好多闲置的进程一直不释放, 导致内存占用过大,然后开始寻求解决办法,经过一番查找发现,FastCGI 进程一旦加载就不会释放,当其工作完成后,就休眠于 FastCGI 系统池中,等待下一次被唤醒。我一直用的是 php-fpm 默认配置,这个配置对于我来说可能有点不合适,需要修改配置文件。下面是一些优化的技巧:

1、php-fpm优化参数介绍

分别有:pm、pm.max_children、pm.start_servers、pm.min_spare_servers、pm.max_spare_servers。

pm:表示使用那种方式,有两个值可以选择,就是static(静态)或者dynamic(动态),默认为 dynamic。

下面4个参数的意思分别为:

pm.max_children:静态方式下开启的php-fpm进程数量

pm.start_servers:动态方式下的起始php-fpm进程数量

pm.min_spare_servers:动态方式下的最小php-fpm进程数

pm.max_spare_servers:动态方式下的最大php-fpm进程数量

区别:

如果dm设置为 static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。

如果dm设置为 dynamic,那么pm.max_children参数失效,后面3个参数生效。

系统会在php-fpm运行开始 的时候启动pm.start_servers个php-fpm进程,

然后根据系统的需求动态在pm.min_spare_servers和pm.max_spare_servers之间调整php-fpm进程数

选择哪种执行方式比较好呢?事实上,跟Apache一样,运行的PHP程序在执行完成后,或多或少会有内存泄露的问题。根据网上的资料,对于内存大的服务器(8G)以上,指定静态的max_children实际上更为妥当,因为这样不需要进行额外的进程数目控制,会提高效率。对于小内存的服务器,动态方式会结束掉多余的进程,可以回收释放一些内存,所以推荐在内存较少的服务器或VPS上使用。

php-fpm 默认的配置是这样的:

[root@feiyu etc]# cat php-fpm.conf | grep -v ';' | grep -v '^$'
[global]
pid = run/php-fpm.pid
 
 
[www]
user = nobody
group = nobody
listen = 127.0.0.1:9000
 
pm = dynamic
pm.max_children = 20
pm.start_servers = 10
pm.min_spare_servers = 5
pm.max_spare_servers = 20
 
pm.max_requests = 500

我调整后的配置:

[global]
pid = run/php-fpm.pid
 
 
[www]
user = nobody
group = nobody
listen = 127.0.0.1:9000
 
pm = dynamic
pm.max_children = 20
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 10
 
pm.max_requests = 300

然后重启 php-fpm ,重启完内存使用是这样的,通过上面的对比可以看出 php-fpm 消耗了不少内存:


服务运行稳定以后系统的内存使用是这样的:

middle


DevOps-田飞雨 》》转载请注明源地址
喜欢 (7)or分享 (0)
发表我的评论
取消评论
*

表情 贴图 加粗 链接 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
(10)个小伙伴在吐槽
  1. 你的wordpress插件有内存泄漏吧,怎么耗费这么大内存?我的内存512跑了三个网站都没出现过满载
    零上2016-05-29 12:50 回复
    • 我也没想到内存占用这么多 ,我用的插件有 Akismet,Google XML Sitemaps,SI CAPTCHA Anti-Spam,WP SMTP,WP 统计,XML Sitemap & Google News feeds,七牛图床,你觉得哪个会有问题
      struggling  2016-05-29 15:05 回复
      • Akismet,SI CAPTCHA Anti-Spam,WP SMTP可以替换为多说,自带的并不好用,而且我没收到评论邮件通知。Google XML Sitemaps,XML Sitemap直接用百度站长后台的自动推送js,sitemap现在没那么重要了。谷歌sitemaps你不做谷歌也会全收录。本来wp就不快,这一推插件。。
        零上2016-05-31 09:42 回复
  2. 我觉得好像评论插件有问题,已经换了。目前内存使用量趋于稳定
    struggling-youth-  2016-05-31 16:14 回复
  3. 谢谢分享。
  4. 感谢分享
    阅读网2016-06-01 12:26 回复
  5. 感谢分享、
    小见2016-06-03 15:47 回复
  6. 评论终于正常了。。。。
    深蓝2016-06-04 22:15 回复
  7. 感谢楼主的分享,我很喜欢,赞赞,我的网站http://www.magicessay.org/
    王静2016-07-22 19:57 回复