一、問(wèn)題描述
1、19號(hào)手動(dòng)升級(jí)到wordpress4.1,21號(hào)早上7點(diǎn)看網(wǎng)站php探針,發(fā)現(xiàn)系統(tǒng)負(fù)載過(guò)高,差不多在1到1.5之間。
2、雖然對(duì)于雙核處理器,這個(gè)值還可以接受,但是之間負(fù)載都只有0.2左右,而網(wǎng)站流量又沒(méi)有突然增加很多,所以推定肯定是出問(wèn)題了。
3、eth 外網(wǎng)流量正常,lo 本地流量增長(zhǎng)很快,reboot系統(tǒng)后(之間服務(wù)器已經(jīng)穩(wěn)定運(yùn)行了632天9小時(shí)25分鐘),1個(gè)小時(shí)不到就有了1G的流量。
4、top命令發(fā)現(xiàn)php-cgi 占用cpu很多,大部分時(shí)間都在80%到90%之間,cpu time+ 時(shí)間很長(zhǎng)。
二、解決方法
1、百度搜索:php cgi cpu找到文章
https://www.yii666.net/article/92975.htm
2、修改php-fpm.conf
request_terminate_timeout 0s 改為30s
request_slowlog_timeout 0s 改為3s
重啟php-fpm:/usr/local/php/sbin/php-fpm restart
3、查看slow.log發(fā)現(xiàn),每一個(gè)統(tǒng)計(jì)時(shí)間點(diǎn)里都有如下提示
script_filename = /網(wǎng)站路徑/wp-cron.php
[0xbfcaa950] do_action_ref_array() /網(wǎng)站路徑/wp-cron.php
4、想到可能和wp-cron.php有關(guān),于是百度搜索:wp-cron.php找到:
https://www.yii666.net/cms/495321.html
5、于是找到php-cgi進(jìn)程占用cpu資源導(dǎo)致服務(wù)器負(fù)載過(guò)高的解決方法:禁用WP-Cron
編輯wordpress wp-config.php,加入:define(‘DISABLE_WP_CRON’, true);
然后 /root/lnmp restart 重啟lnmp
重啟之后cpu 占用終于正常,網(wǎng)站負(fù)載也減了下來(lái),slow.log 也不再增加新的內(nèi)容
三、排除可能的原因
1、禁用hyper cache
開(kāi)始覺(jué)得可能hyper cache生成的緩存文件過(guò)多引起php負(fù)載,禁用hyper cache插件后發(fā)現(xiàn)負(fù)載非但不降,反而升了,說(shuō)明:不是hyper cache的問(wèn)題且hyper cache可以起到降低php負(fù)載的作用。
2、刪除eAccelerator
https://www.yii666.net/article/92978.htm
依據(jù)這篇文章提醒:vi /usr/local/php/etc/php.ini 刪除文件末尾Accelerator的那幾行配置刪掉,保存重啟lnmp,發(fā)現(xiàn)問(wèn)題依舊,所以也排除了eAccelerator的原因,之后再重新在php.ini中添加上eAccelerator的配置。
3、file_get_contents的問(wèn)題
https://www.yii666.net/article/28030.htm
https://www.yii666.net/article/92980.htm
參考上邊兩篇文章,ll /proc/PID/fd 沒(méi)有發(fā)現(xiàn)異常。
yum install strace 安裝(不安裝會(huì)提示錯(cuò)誤:-bash: strace: command not found) 后
strace -p pid,有類(lèi)似的提示錯(cuò)誤:poll([{fd=4, events=POLLIN}], 1, 0) = 0 (Timeout)
頁(yè)面不停的閃動(dòng),服務(wù)器負(fù)載驟增。
兩篇文章中提到的:stream_context_create 設(shè)置超時(shí)時(shí)間,技術(shù)太差,完全看不懂要如何操作,所以也沒(méi)辦法向下進(jìn)行,放棄。
4、php5.2 和curl的兼容問(wèn)題
解決方法:設(shè)置curl超時(shí)時(shí)間
curl_setopt($ch, CURLOPT_TIMEOUT, 2);文章來(lái)源:http://www.zghlxwxcb.cn/news/detail-422866.html
也不知如何操作,放棄。文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-422866.html
到了這里,關(guān)于php-cgi進(jìn)程cpu負(fù)載過(guò)高:禁用wordpress定時(shí)任務(wù)wp-cron.php的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!