佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 服務(wù)器大量php-cgi.exe進(jìn)程導(dǎo)致CPU占用100%的解決方法

服務(wù)器大量php-cgi.exe進(jìn)程導(dǎo)致CPU占用100%的解決方法

熱門標(biāo)簽:硅谷的囚徒呼叫中心 智能手機(jī) 檢查注冊表項(xiàng) 網(wǎng)站建設(shè) 百度競價點(diǎn)擊價格的計算公式 阿里云 美圖手機(jī) 使用U盤裝系統(tǒng)

 windows 2003+IIS6中優(yōu)化fastcgi配置文件fcgiext.ini,減少php-cgi.exe進(jìn)程數(shù)量和所占內(nèi)存大小

本來聽說fastcgi比isapi好就在服務(wù)器中裝上了,配置環(huán)境為windows 2003+IIS6+fastcgi(FCGI)+PHP5.2.17,經(jīng)過與很長一段時間觀察,發(fā)現(xiàn)工作在FastCGI模式下的PHP會占用越來越多的內(nèi)存,訪問量稍微多點(diǎn)php-cgi進(jìn)程就多了N個,同樣情況下能比原來用isapi模式的時候多出幾百M(fèi),我的服務(wù)器內(nèi)存只有2G傷不起啊。

我在網(wǎng)上搜索了一下,發(fā)現(xiàn)還有不少人面臨同樣的問題。來自PHP官方的一個比較正式的解釋是:php-cgi進(jìn)程并沒有內(nèi)存泄漏,php-cgi會在每個請求結(jié)束的時候回收腳本使用的全部內(nèi)存,但是并不會釋放給操作系統(tǒng),而是繼續(xù)持有以應(yīng)對下一次PHP請求。這樣做大概是為了減少內(nèi)存碎片化或者解決從系統(tǒng)申請內(nèi)存之后又釋放回操作系統(tǒng)所需要的時間不可控問題??墒侨绻既灰淮蜳HP請求使用了諸如ftp或者zlib這樣的大內(nèi)存操作,那么將導(dǎo)致一大塊系統(tǒng)內(nèi)存被php-cgi持續(xù)占有,不能被利用。
解決這個問題的辦法是在web服務(wù)器配置中優(yōu)化fastcgi配置文件參數(shù)。

在C:\WINDOWS\system32\inetsrv\fcgiext.ini 文件中可以設(shè)定php-cgi進(jìn)程相關(guān)參數(shù),如:

[Types]
php = PHP
[PHP]
ExePath=C:\php-5.3.8-nts-Win32-VC9-x86\php-cgi.exe
maxInstances=100
InstanceMaxRequests=10000
EnvironmentVars=PHP_FCGI_MAX_REQUESTS:10000
RequestTimeout=600
ActivityTimeout=900

在上面的配置中:

ExePath  指定了FastCGI解析程序的路徑,
instanceMaxRequests  指定了每個實(shí)例可以處理的最大請求數(shù),
maxInstances 指定可以啟動的最大實(shí)例數(shù)目,
EnvironmentVars 創(chuàng)建了一個環(huán)境變量 PHP_FCGI_MAX_REQUESTS ,默認(rèn)值設(shè)為10000,
requestTimeout  指定了請求的超時時間為600秒,
activityTimeout  指定了活動會話超時時間為900秒。
一下是建議值:
maxInstances=
把這個值改小

建議

512M 內(nèi)存的改maxInstances=50
1G 內(nèi)存的改maxInstances=80
2G 內(nèi)存的改maxInstances=140

再修改
InstanceMaxRequests=
把這個值改小

建議

512M 內(nèi)存的改InstanceMaxRequests=200
1G 內(nèi)存的改InstanceMaxRequests=300
2G 內(nèi)存的改InstanceMaxRequests=500

改完, 重啟IIS。

instanceMaxRequests  PHP_FCGI_MAX_REQUESTS  這兩個參數(shù)決定了一個php-cgi進(jìn)程被創(chuàng)建出來之后,最多接受的PHP請求數(shù),在lighttpd中默認(rèn)配置是10000。也就是說這個php-cgi進(jìn)程每接受10000次PHP請求后會終止,釋放所有內(nèi)存,并重新被管理進(jìn)程啟動。如果把它降低,比如改成100,那么php-cgi重啟的周期會大大縮短,偶然的高內(nèi)存操作造成的問題影響時間也會縮短。
maxInstances 這個參數(shù)指定可以啟動的最大實(shí)例數(shù)目,即php-cgi.exe進(jìn)程的數(shù)目。如果把它降低,比如改成100,那么在任務(wù)管理器的進(jìn)程中最多只有php-cgi.exe進(jìn)程,php-cgi.exe所占用的總內(nèi)存將大大減少。
我現(xiàn)在用的服務(wù)器為windows 2003操作系統(tǒng),4G內(nèi)存,一個php-cgi.exe程序占用7-25M內(nèi)存,我把maxInstances值調(diào)為300,減少了php-cgi.exe進(jìn)程的總數(shù)量,占用內(nèi)存也減小了,反應(yīng)速度比以前快了不少,至少調(diào)整到多少,可根據(jù)您的站點(diǎn)訪問量來決定。

win2008服務(wù)器,fastCGI完美設(shè)置教程

在WIN2008的IIS7上使用FASTCGI調(diào)用PHP-CGI.EXE,默認(rèn)只有4個進(jìn)程,這樣對于大流量的網(wǎng)站為說,進(jìn)程數(shù)不足帶來的進(jìn)程排隊(duì)現(xiàn)象十分嚴(yán)重,解決方案如下。

32位系統(tǒng) http://www.iis.net/Downloads/files/AdminPack/TP2/AdminPack_x86.msi
64位系統(tǒng) http://www.iis.net/Downloads/files/AdminPack/TP2/AdminPack_amd64.msi

下載如下工具,安裝后,如下圖。



添加

PHP_FCGI_MAX_REQUESTS = 10000

添加后,不用重啟IIS,就能在進(jìn)程管理器看到效果。

似乎并沒有達(dá)到設(shè)定的值,不過瀏覽網(wǎng)站明顯感覺到性能的提示。

內(nèi)存占用~~ 其實(shí)微軟的系統(tǒng)有一個不好處在于, 服務(wù)器的內(nèi)存占用,要盡量讓服務(wù)去使用,而并不像客戶端使用一樣,留足夠多的內(nèi)存給用戶的應(yīng)用程序。

我在這里要提醒大家注意的是以下兩個參數(shù)值得設(shè)置:

InstanceMaxRequests:fastcgi進(jìn)程(php-fcgi.exe)能處理的最大請求數(shù),超過了就要回收,默認(rèn)是200

PHP_FCGI_MAX_REQUESTS:php自身控制的最大請求數(shù),默認(rèn)是500

既然要用fastcgi去運(yùn)行cgi,那肯定是不想php自身去限制最大請求數(shù)??!

所以,一定要保證InstanceMaxRequests小于 或 等于 PHP_FCGI_MAX_REQUESTS,這樣php自身永遠(yuǎn)沒有機(jī)會去回收進(jìn)程。

可以看micorsoft說的:

Make sure that FastCGI always recycles Php-cgi.exe processes before native PHP recycling starts. The configuration property instanceMaxRequests controls the FastCGI process-recycling behavior. This property specifies how many requests FastCGI will process before recycling. PHP also has a similar process-recycling functionality that is controlled by the environment variable PHP_FCGI_MAX_REQUESTS. By setting instanceMaxRequests to a value that is smaller than or equal to PHP_FCGI_MAX_REQUESTS, you can make sure that the native PHP process-recycling logic will never start.

服務(wù)器php-cgi.exe進(jìn)程過多,導(dǎo)致CPU占用100%的解決方法

使用iis服務(wù)器中經(jīng)常會出現(xiàn)php-cgi.exe進(jìn)程過多,導(dǎo)致CPU占用100%,最終造成網(wǎng)站運(yùn)行過慢甚至卡死的情況,重啟iis會好一會,過一段時間久出現(xiàn)這種情況,為什么會出現(xiàn)這種情況呢,應(yīng)該怎么解決呢,開始的時候我一直手動結(jié)束php-cgi程序,雖然可以臨時解決問題,但是不是長久之計,我百度了下,出現(xiàn)該問題一般為程序方面問題,如程序采用fastcgi方式運(yùn)行PHP,而程序設(shè)置的StartProcesses又偏大,如6甚至更大。下面是我整理的對php-cgi.ext過多引起服務(wù)器cup%的解決方法,希望對大家有幫助;大多數(shù)情況是發(fā)生在第四項(xiàng)上;

解決參考:

1.檢查系統(tǒng)盤空間。查看系統(tǒng)臨時文件是否過多,mysql數(shù)據(jù)庫的臨時文件默認(rèn)存到了c:/windows/temp,導(dǎo)致累積了幾萬甚至上百萬的小文件,壓垮系統(tǒng)盤。

del *.* 刪除所有文件

如果上面的命令不夠強(qiáng)悍,可以使用下面的代碼

del /f /q /s tmp\*.*

2.PHP是一種廣泛使用的動態(tài)腳本語言,不過在IIS中并沒有內(nèi)置對PHP語言的支持,因此如果需要使用PHP,必須自行安裝。PHP可以安裝為CGI模式或者ISAPI模式,由于ISAPI模式具有更高的性能,因此我建議大家使用ISAPI模式。

3.如能修改程序,建議將程序配置文件中的StartProcesses值縮到2,看是否改善。

4.看是否服務(wù)器有問題攻擊現(xiàn)象。

標(biāo)簽:湖北 懷化 黃山 煙臺 通遼 湘潭 賀州 山南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《服務(wù)器大量php-cgi.exe進(jìn)程導(dǎo)致CPU占用100%的解決方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    类乌齐县| 阜南县| 嘉鱼县| 囊谦县| 南郑县| 区。| 汝州市| 炉霍县| 固阳县| 金阳县| 吉安市| 阿坝县| 论坛| 盐边县| 邵阳市| 特克斯县| 厦门市| 和田县| 嘉定区| 闽侯县| 赤壁市| 涪陵区| 琼海市| 浦江县| 胶南市| 娄烦县| 正蓝旗| 特克斯县| 左贡县| 安西县| 饶平县| 阿荣旗| 天峻县| 姜堰市| 呼图壁县| 中方县| 宁蒗| 东阳市| 青铜峡市| 阿拉善右旗| 谢通门县|