如何對512M內存的vps apache進行優化配置(perfork模式)

 本文是對512M 內存並裝有apache的vps進行優化,請不要跟我說裝nginx就強多了,確實如此,但是你這樣說的話,這篇文章就沒什麼意義了,哈哈。那麼進入正題吧!

操作系統(linux):CentOS 5.5 32位(並不是我說這個比較好,只是Cents我用得比較熟練)

  • 內存:512M
  • cpu:1G(1000MHz,vps實際有沒有這個數,很難說)
  • apache:2.2(建議低版本的,升級到高版本,畢竟舊版有很多問題,且性能也是高版本好點)

運行的主要是PHP程序,其他的不多說了,與本文關係不大。

首先,如題所說,本文所說的優化是針對apache 2.2以上版本,及使用perfork MPM模式的。perfork是apache在linux下默認安裝下的模式,如果使用apache作爲服務器的放在,還是使用perfork模式比較好,worker模式下對php某些功能並不支持。如果你使用的是win系統或都沒有使有和perfork,那麼下面可以選擇不看或抱着學習的態度看看咯。

以下內容均屬於博主自己的見解,實際測試請根據你的服務器,程序及其他因素按需處理。

一般情況下,我們需要優化apache就是因爲apache佔用大量的內存,導致vps當機,因爲perfork是多進程處理的,每個進程都會點用一定的內存數量。所以限制httpd進程的數量,從而達到優化apache的作用。影響單個httpd進程的內存大小,主要都是加載模塊,至少什麼模塊是合適的,我也很難說,因爲這個是按由你的需要而定的。網上有些人說,絕大部分都會用不上的模塊列出來,我認爲這個是有很大的誤導作用,因爲絕大部分人中,也許你就是其中一個。將有用的模塊屏蔽掉,最壞的情況,就是重啓apache出錯,或部分功能無法使用。所以我也不會列出什麼最少模塊加載方案什麼的。所以,我只會說出一些參考。

apache(perfork)下的模塊加載,並不是模塊加載列表,沒有的模塊並不是屏蔽掉了,只是我也不清楚它的實際作用。

一、對於apache2.2,模塊名有cache的一般都是有用的,因爲有不少的這類模板都是2.1以上的apache才支持的,所以這類的模塊不會是無緣無緣而存在的。

二、很有可能或必用到的模塊有:


LoadModule auth_basic_module modules/mod_auth_basic.so
  LoadModule authn_file_module modules/mod_authn_file.so
  LoadModule include_module modules/mod_include.so
  LoadModule log_config_module modules/mod_log_config.so
  LoadModule expires_module modules/mod_expires.so
  LoadModule deflate_module modules/mod_deflate.so
  LoadModule headers_module modules/mod_headers.so
  LoadModule setenvif_module modules/mod_setenvif.so
  LoadModule mime_module modules/mod_mime.so
  LoadModule autoindex_module modules/mod_autoindex.so
  LoadModule negotiation_module modules/mod_negotiation.so
  LoadModule dir_module modules/mod_dir.so
  LoadModule alias_module modules/mod_alias.so
  LoadModule rewrite_module modules/mod_rewrite.so

三、我粗略點了一下apache裏面的模塊約在50+以,要從中選擇人人都適用的模塊加載列表是不可能的,至少cgi模塊我是不會用,但不排除你不會用。

模塊加載這一塊就說到這裏,這個大家多百度,多用自然會識別出一些有用模塊並漸漸屏蔽不使用的模塊。

接下來,就是最爲重要的perfork配置,也是困擾了我很久的問題,儘管參數就那麼6個,那是卻足以讓你的vps當機。先列出需要修改的參數,修改位於httpd.conf的文件裏面


Timeout 30
KeepAlive On
MaxKeepAliveRequests 80
KeepAliveTimeout 15
<IfModule prefork.c>
ServerLimit 150
StartServers      5
MinSpareServers   5
MaxSpareServers   10
MaxClients       150
MaxRequestsPerChild 4000
</IfModule>

上面的代碼就是要修改的,實際上我們是要修改perfork裏在的參數,之所以將Timeout,KeepAlive等也寫出來,是因爲這個也是影響apache性能的。

Timeout是一個連接多少時間後斷開,這個參數設置在30-60是一般的php程序都是適用的,至少要運行一些要佔用大量時間的php程序,那麼適當調高也是可以的,但請不要太高,否則會影響apache性能,本次優化我們使用30就很足夠了。

MaxKeepAliveRequests 是一個連接最大的請求量,對於頁面有較多的圖片等元素,可以適當調高一點,對於一般的網頁設置在80-120是足夠的,我們就設置爲100,如果設置太高會導致httpd長時間不能退出釋放內存的。

KeepAliveTimeout 是當用戶處理一次連接時,如果在該參數的時間內還有請求則會繼續執行,不需要重新創建新的連接,直到達到MaxKeepAliveRequests的最大值纔會退出。對於perfork模式下的,有人認爲是將KeepAlive Off會比較好,但是對於絕大多數的網站都會不多不少有些圖片元素,所以將該項打開,並將KeepTimeOut設置在2-5秒,不但有效提高服務器性能,也能加快頁面打開速度。

接下來,就是正式進入perfork的參數設置了,不想服務器運行一會就內存佔滿的得看看哦。

首先是參數ServerLimit就是服務器最大支持同時連接的客戶端,該值將決定下面參數MaxClient可以設定的值的範圍。ServerLimit實際上只是起到一個限制的作用,並沒有實際有作用,也許有,我就不知道了。實際上起到作用的是,MaxClient參數,但這個值又受ServerLimit的限制,等下會講。

另三個參數StartServers,MinSpareServers,MaxSpareServers,爲什麼將這三個參數一起說呢,因爲這三個數是聯繫在一起的。這三個數都是決定空閒進程數量,StartServers應該範圍就是MinSpareServers和MaxSpareServers之間。否則,apache會自動將該值還原到兩都之間,所以不要浪費不必要的資源。按照perfork默認的配置,這三個參數分別爲:5,5,10。但是對於只有512M內存的vps來說,我認爲還是有過大的負載。因此,我認爲在這裏應該退一步,將這三個參數設置爲4,4,10,看起來和上面5,5,10並沒有什麼不同,最大值還是10,但在實際使用中4,4,10釋放的內存速度會明顯比5,5,10快很多。

接下來就是MaxClient最大支持多少客戶端在同一時間連接服務器,簡單說就是最大併發數支持,這個沒有特別需要說的。對於512M的vps你也別想你的站能承受百萬PV,使用默認的150已是超出負載的了。一般將ServerLimit和MaxClient設爲一樣值即可。

最後就是MaxRequestsPerChild參數,一個進程在處理多少次之後退出,設置爲0則是無限次,也就是說不會退出,那麼httpd進程也不會退出。那麼,你就等着你的vps當機重啓去吧。對於這個參數,我粗略地搜索了一下,不少人推薦在1000次,也有100次的。據我的測試,對於內存只有512M的vps來說,該值設置在500以上都會很快佔滿內存,但不至少於當機。而觀察得知,一但內存佔滿,cpu的使用率幾乎變爲0了。由此可知,當機了那什麼都幹不了了,還不如消耗多一點cpu資源避免,提高穩定性。所以,我最後的決定是將該值定義在30-40之間。這樣設定後,可以看出,內存釋放速度得到很大的提升,但也可以看到cpu也在頻繁上下跳動。這樣設置,即使內存佔滿,也能在最短時間恢復正常。

所以對於512MB的vps,apache(perfork模式)最後的優方配置爲:


Timeout 30
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 2
<IfModule prefork.c>
ServerLimit 150
StartServers      4
MinSpareServers   4
MaxSpareServers   10
MaxClients       150
MaxRequestsPerChild 40
</IfModule>

這樣,我們的配置基本完成,進行負載測試即可。負載測試,我們使用ab測試,先聲明一點,是用你本地的虛擬機去測試服務器上的一個靜態頁面,而不是在服務器上測試。之前,我就是這樣做,因爲網速一樣,效果都是比較好的,但別人都是不同網速的,所以服務器上測試是不準備的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章