首页 > 电脑专区 > CMS教程 > WordPress >

php-cgi进程cpu负载过高:禁用wordpress定时任务wp-cron.php

来源:互联网 2023-03-14 12:48:23 151

一、问题描述XVr办公区 - 实用经验教程分享!

1、19号手动升级到WORDPRESS4.1,21号早上7点看网站php探针,发现系统负载过高,差不多在1到1.5之间。XVr办公区 - 实用经验教程分享!

2、虽然对于双核处理器,这个值还可以接受,但是之间负载都只有0.2左右,而网站流量又没有突然增加很多,所以推定肯定是出问题了。XVr办公区 - 实用经验教程分享!

3、eth 外网流量正常,lo 本地流量增长很快,reboot系统后(之间服务器已经稳定运行了632天9小时25分钟),1个小时不到就有了1G的流量。XVr办公区 - 实用经验教程分享!

4、top命令发现php-cgi 占用cpu很多,大部分时间都在80%到90%之间,cpu time 时间很长。XVr办公区 - 实用经验教程分享!

二、解决方法XVr办公区 - 实用经验教程分享!

1、百度搜索:php cgi cpu找到文章XVr办公区 - 实用经验教程分享!

https://www.jb51.net/article/92975.htmXVr办公区 - 实用经验教程分享!

2、修改php-fpm.confXVr办公区 - 实用经验教程分享!

request_terminate_timeout 0s 改为30sXVr办公区 - 实用经验教程分享!

request_slowlog_timeout 0s 改为3sXVr办公区 - 实用经验教程分享!

重启php-fpm:/usr/local/php/sbin/php-fpm restartXVr办公区 - 实用经验教程分享!

3、查看slow.log发现,每一个统计时间点里都有如下提示XVr办公区 - 实用经验教程分享!

script_filename = /网站路径/wp-cron.phpXVr办公区 - 实用经验教程分享!

[0xbfcaa950] do_action_ref_array() /网站路径/wp-cron.phpXVr办公区 - 实用经验教程分享!

4、想到可能和wp-cron.php有关,于是百度搜索:wp-cron.php找到:XVr办公区 - 实用经验教程分享!

https://www.jb51.net/cms/495321.htmlXVr办公区 - 实用经验教程分享!

5、于是找到php-cgi进程占用cpu资源导致服务器负载过高的解决方法:禁用WP-CronXVr办公区 - 实用经验教程分享!

编辑WORDPRESS wp-config.php,加入:define(‘DISABLE_WP_CRON’, true);XVr办公区 - 实用经验教程分享!

然后 /root/lnmp restart 重启lnmpXVr办公区 - 实用经验教程分享!

重启之后cpu 占用终于正常,网站负载也减了下来,slow.log 也不再增加新的内容XVr办公区 - 实用经验教程分享!

三、排除可能的原因XVr办公区 - 实用经验教程分享!

1、禁用hyper cacheXVr办公区 - 实用经验教程分享!

开始觉得可能hyper cache生成的缓存文件过多引起php负载,禁用hyper cache插件后发现负载非但不降,反而升了,说明:不是hyper cache的问题且hyper cache可以起到降低php负载的作用。XVr办公区 - 实用经验教程分享!

2、删除eAcceleratorXVr办公区 - 实用经验教程分享!

https://www.jb51.net/article/92978.htmXVr办公区 - 实用经验教程分享!

依据这篇文章提醒:vi /usr/local/php/etc/php.ini 删除文件末尾Accelerator的那几行配置删掉,保存重启lnmp,发现问题依旧,所以也排除了eAccelerator的原因,之后再重新在php.ini中添加上eAccelerator的配置。XVr办公区 - 实用经验教程分享!

3、file_get_contents的问题XVr办公区 - 实用经验教程分享!

https://www.jb51.net/article/28030.htmhttps://www.jb51.net/article/92980.htmXVr办公区 - 实用经验教程分享!

XVr办公区 - 实用经验教程分享!

参考上边两篇文章,ll /proc/PID/fd 没有发现异常。XVr办公区 - 实用经验教程分享!

yum install strace 安装(不安装会提示错误:-bash: strace: command not found) 后XVr办公区 - 实用经验教程分享!

strace -p pid,有类似的提示错误:poll([{fd=4, events=POLLIN}], 1, 0) = 0 (Timeout)XVr办公区 - 实用经验教程分享!

页面不停的闪动,服务器负载骤增。XVr办公区 - 实用经验教程分享!

两篇文章中提到的:stream_context_create 设置超时时间,技术太差,完全看不懂要如何操作,所以也没办法向下进行,放弃。XVr办公区 - 实用经验教程分享!

4、php5.2 和curl的兼容问题XVr办公区 - 实用经验教程分享!

解决方法:设置curl超时时间XVr办公区 - 实用经验教程分享!

curl_setopt($ch, CURLOPT_TIMEOUT, 2);XVr办公区 - 实用经验教程分享!

也不知如何操作,放弃。XVr办公区 - 实用经验教程分享!

以上方法由办公区教程网编辑摘抄整理自互联网可供大家参考!XVr办公区 - 实用经验教程分享!


标签: php-cgiCPU负载WORDPRESS

办公区 Copyright © 2016-2023 www.bgqu.net. Some Rights Reserved. 备案号:湘ICP备2020019561号统计代码