lnmp云主机CPU占用一直100%的排查

回复 收藏
昨晚我的云主机cpu一直100%,网站可以打开但是很慢,需要2秒+
配置是1核2g,50g数据盘
QQ截图20160118115038.jpg
QQ截图20160118115058.jpg
QQ截图20160118115132.jpg
QQ图片20160118114506.png
QQ图片20160118114521.png



排查了一下,不是流量攻击,也没有异常进程
最后排查到php-fpm.conf
pm = dynamic   
pm.max_children = 50   
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 50


经朋友指点是上面的参数设置太大了,重新设置为下面的配置,重启php-fpm服务
service php-fpm restart

现在的配置文件
[global]
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
[www.80ops.cn]     
listen = 127.0.0.1:9000
;listen = /tmp/php-fcgi.sock
user = php-fpm
group = php-fpm
listen.owner = nobody
listen.group = nobody
pm = dynamic   
pm.max_children = 20   
pm.start_servers = 5   
pm.min_spare_servers = 5
pm.max_spare_servers = 20
pm.max_requests = 500   
rlimit_files = 65535      
slowlog = /usr/local/php-fpm/var/log/www.80ops.cn.log   
request_slowlog_timeout = 1s
php_admin_value[open_basedir]=/mydata/www/wordpress:/tmp/   

一直用w命令查看,负载开始回落,网站打开速度也正常了

附上一篇文章
http://www.web-build.com.au/phpfpm-pm/
php-fpm的静态和动态执行方式比较

前段时间配置php-fpm的时候,无意间发现原来他还有两种执行方式。与Apache一样,他的进程数也是可以根据设置分为动态和静态的。

而php-fpm也是同样存在两种方式,一种是直接开启指定数量的php-fpm进程,不再增加或者减少;另一种则是开始的时候开启一定数量的php-fpm进程,当请求量变大的时候,动态的增加php-fpm进程数到上限,当空闲的时候自动释放空闲的进程数到一个下限。

这两种不同的执行方式,可以根据服务器的实际需求来进行调整。

这里先说一下涉及到这个的几个参数吧,他们分别是pm、pm.max_children、pm.start_servers、pm.min_spare_servers和pm.max_spare_servers。

pm表示使用那种方式,有两个值可以选择,就是static(静态)或者dynamic(动态)。在更老一些的版本中,dynamic被称作apache-like。这个要注意看配置文件给出的说明了。

下面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程序在执行完成后,或多或少会有内存泄露的问 题。这也是为什么开始的时候一个php-fpm进程只占用3M左右内存,运行一段时间后就会上升到20-30M的原因了。所以,动态方式因为会结束掉多余 的进程,可以回收释放一些内存,所以推荐在内存较少的服务器或者VPS上使用。具体最大数量根据 内存/20M 得到。比如说512M的VPS,建议pm.max_spare_servers设置为20。至于pm.min_spare_servers,则建议根据服 务器的负载情况来设置,比较合适的值在5~10之间。

然后对于比较大内存的服务器来说,设置为静态的话会提高效率。因为频繁开关php-fpm进程也会有时滞,所以内存够大的情况下开静态效果会更好。数量也可以根据 内存/30M 得到。比如说2GB内存的服务器,可以设置为50;4GB内存可以设置为100等。

本站是建立在512M的VPS上,因此我设置的参数如下:

pm=dynamic
pm.max_children=20
pm.start_servers=5
pm.min_spare_servers=5
pm.max_spare_servers=20

这样就可以最大的节省内存并提高执行效率。

附各参数说明:

pm string

设置进程管理器如何管理子进程。可用值:static,ondemand,dynamic。必须设置。

static - 子进程的数量是固定的(pm.max_children)。
ondemand - 进程在有需求时才产生(当请求时,与 dynamic 相反,pm.start_servers 在服务启动时即启动。
dynamic -子进程的数量在下面配置的基础上动态设置:pm.max_children,pm.start_servers,pm.min_spare_servers,pm.max_spare_servers。

pm.max_children int

pm 设置为 static 时表示创建的子进程的数量,pm 设置为 dynamic 时表示最大可创建的子进程的数量。必须设置。
该选项设置可以同时提供服务的请求数限制。类似 Apache 的 mpm_prefork 中 MaxClients 的设置和 普通PHP FastCGI中的 PHP_FCGI_CHILDREN 环境变量。

pm.start_serversin
设置启动时创建的子进程数目。仅在 pm 设置为 dynamic 时使用。默认值:min_spare_servers + (max_spare_servers - min_spare_servers) / 2。

pm.min_spare_servers int
设置空闲服务进程的最低数目。仅在 pm 设置为 dynamic 时使用。必须设置。

pm.max_spare_servers int
设置空闲服务进程的最大数目。仅在 pm 设置为 dynamic 时使用。必须设置。

pm.max_requests int
设置每个子进程重生之前服务的请求数。对于可能存在内存泄漏的第三方模块来说是非常有用的。如果设置为 '0' 则一直接受请求,等同于 PHP_FCGI_MAX_REQUESTS 环境变量。默认值:0。



总结
动态的话适合小内存服务器,一般 假设每个php-fpm进程20M内存,那么1G内存除以20M 等于pm.max_children=50
静态的话适合大内存服务器,一般 假设每个php-fpm进程30M内存,那么2G内存除以30M 等于pm.max_spare_servers =60




2016-01-18 11:55 举报
已邀请:
0

369666951

赞同来自:

最后总结是不是写反了
0

超大大

赞同来自:

{:4_114:}
0

阿铭 管理员

赞同来自:

当出现高负载时,可以打开php-fpm的slow日志,分析是哪些php代码执行慢,进行优化,往往和后端的mysql有关联,所以同时需要查看mysql的慢查询日志。
0

lyhabc

赞同来自:

阿铭 发表于 2016-1-18 14:05
当出现高负载时,可以打开php-fpm的slow日志,分析是哪些php代码执行慢,进行优化,往往和后端的mysql有关 ...

好的
0

qidi2015

赞同来自:

目测用的腾讯云的主机。
0

lyhabc

赞同来自:

qidi2015 发表于 2016-1-18 15:13
目测用的腾讯云的主机。

是   
0

qidi2015

赞同来自:


最近腾讯的CDN搞活动,一个月免费50GB流量,你网站前端还是加一个CDN吧,IP直接暴露在外面不好。
0

lyhabc

赞同来自:

qidi2015 发表于 2016-1-19 08:18
最近腾讯的CDN搞活动,一个月免费50GB流量,你网站前端还是加一个CDN吧,IP直接暴露在外面不好。

cdn买不起啊{:4_102:}
0

snake

赞同来自:

学习了

回复帖子,请先登录注册

退出全屏模式 全屏模式 回复
评分
可选评分理由: