PHP應用提速面面觀(轉)

subid發表於2007-08-17
PHP應用提速面面觀(轉)[@more@]PHP最大的優點之一顯然在於它的快速度。一般情況下PHP總是具有足夠的速度支援Web內容動態生成,許多時候你甚至無法找出比它更快的方法。然而,當你不得不面對龐大的訪問量、高負荷的應用、有限的頻寬以及其他各種帶來效能瓶頸的因素時,你可能會問問自己是否可以做點什麼讓網站執行得更好。或許只要加上一個很不起眼的免費模組,你的PHP應用效能以及Web伺服器響應速度就會有顯著的改善。本文討論的就是如何進一步提高php應用的效能,給使用者以更美妙的瀏覽感受。本文分三個方面(程式碼最佳化、快取、內容壓縮)闡述提高PHP應用效能的各種技術,並介紹各個領域的知名產品。

程式碼最佳化
首先我們來看看程式碼最佳化。注意,這裡的程式碼最佳化可不是指把程式碼寫得更加美觀漂亮,因為這恐怕已經是眾所周知沒有必要繼續討論了;另外,如果你已經考慮到了速度問題,很可能你早就對PHP的原始碼作了一些最佳化。不過,有些工具卻能夠自動地幫助我們完成這些繁雜的工作,如Zend Optimizer就是這樣一個工具。Zend Optimizer可以從Zend Technologies免費得到,但你必須同意它的許可約定,注意它不是以GPL方式發行。Zend Optimizer獲取由Zend Engine執行時編譯生成的中間程式碼,並對它進行最佳化,從而使得中間程式碼具有更快的執行效率。

Zend Optimizer的安裝方法非常簡單,你只需下載為自己所用平臺提供的預編譯版本,把下面兩行程式碼加入到php.ini,然後重新啟動Web伺服器即可:

zend_optimizer.optimization_level=15
zend_extension="/path/to/ZendOptimizer.so"
zend_loader.enable=Off

這裡額外增加的第三行程式碼是可選的。禁止zend_loader似乎能夠讓Zend Optimizer的速度更快一點,所以在php.ini中加上這行程式碼是值得的。注意:只有當你不使用Zend Encoder Runtime時,你才可以禁用zend_loader。

快取
如果你想要讓自己龐大的PHP應用有更好的效能表現,採用快取也是一種很好的方法。現在已經有許多快取方案可供選擇,其中包括:Zend Cache,APC,和Afterburner Cache。

所有這些產品都屬於“快取模組”。當第一次出現對.php檔案的請求時,它們會在Web伺服器記憶體中儲存PHP的中間程式碼,此後就用“經過編譯”的版本響應後繼的請求。這種方法確實能夠改善應用的效能,因為它使得磁碟訪問量減低到了最少的程度(程式碼已經讀取和解析),程式碼直接在記憶體中執行使得伺服器響應請求的速度大大提高。當然,快取模組還會監視PHP原始檔的變化,必要時重新快取頁面,從而防止了使用者得到的頁面仍舊由過時的PHP程式碼生成。由於快取模組能夠明顯地降低伺服器的負載、提高PHP應用的響應效率,因此它們非常適合於負載較大的網站使用。

如何選擇這些快取產品
Zend Cache是Zend Technologies公司的商業軟體,而Zend Technologies就是前面提到的那個為我們提供PHP引擎和免費Zend Optimizer的公司。Zend Cache確實是名不虛傳!對於大型的PHP頁面,你可以感覺到第一次執行之後速度就會有所提高,而且伺服器也會有更多的可用資源。遺憾的是這個產品並不免費,不過在有些情形下它仍舊是物超所值。

Afterburner Cache是來自Bware Technologies的免費快取模組,當前這個產品還是Beta版。Afterburner Cache的做法看起來與Zend Cache差不多,但它對效能的改善程度(還)不能與Zend Cache相比,而且它還不能與Zend Optimizer一起工作。

APC是Alternative PHP Cache的縮寫,它是來自Community Connect的又一個免費快取模組。這個產品已經具有足夠的穩定性供正式場合使用,而且它看起來也能在很大程度上提高響應請求的速度。

內容壓縮
前面我們討論了幾種提高PHP應用效能的方法,下面來看看使得瀏覽者感到網站速度太慢的另外一個重要因素:下載速度。如果PHP應用在內部Intranet上執行,而且每一臺客戶機都以100 MB/s的速度連線到伺服器,那麼下載速度應該不是什麼問題。然而,如果伺服器還要為慢騰騰的Modem使用者提供服務,那麼值得考慮內容壓縮。大多數瀏覽器都根據IETF標準支援用gzip進行內容壓縮。這意味著你可以用gzip壓縮內容然而傳送給瀏覽器,由瀏覽器解壓縮資料之後再顯示頁面,這整個過程對使用者來說完全透明。至於伺服器端的內容壓縮,現在已經有許多不同的方法可供使用。

例如,來自Remote Communications的免費Apache模組mod_gzip就具有為支援這類內容編碼的瀏覽器壓縮靜態Web內容的能力。對於絕大多數靜態Web內容,mod_gzip都非常有效。mod_gzip可以方便地編譯到Apache裡面,也可以作為DSO使用。據Remote communications公司說,mod_gzip也能夠壓縮來自mod_php、mod_perl等的動態內容。我試了一次又一次,但看來還是不行。我看了許多關於mod_gzip的論壇和文章,看來到了mod_gzip的下一個版本(可能是1.3.14.6f)這個問題有望得到解決。在此之前,我們可以在網站的靜態部分使用mod_gzip。

然而有時我們確實需要壓縮動態內容,所以必須找找其他辦法。有一種辦法是使用class.gzip_encode.php,這是一個可以用來壓縮頁面內容的PHP類,具體方法是在PHP指令碼的開頭和末尾呼叫該類的某些函式。如果要在網站級實現這個方案,可以從php.ini檔案的auto_prepend以及auto_append指令呼叫這些函式。這種方法雖然有效,但它無疑為高負載的網站帶來了更多的開銷。關於如何使用這個類的詳細說明,請參見它的原始碼。它的原始碼說明相當完善,作者告訴了你所有你必須知道的事情。

PHP 4.0.4有一個新的輸出快取控制程式碼ob_gzhandler,它與前面的類相似,但用法不同。使用ob_gzhandler時要在php.ini中加入的內容如下:

output_handler = ob_gzhandler ;


這行程式碼使得PHP啟用輸出快取,並壓縮它傳送出去的所有內容。如果由於某種原因你不想在php.ini中加上這行程式碼,你還可以透過PHP原始檔所在目錄的.htaccess檔案改變預設的伺服器行為(不壓縮),語法如下:

php_value output_handler ob_gzhandler


或者是從PHP程式碼呼叫,如下所示:

ob_start("ob_gzhandler");


採用輸出快取控制程式碼的方法確實非常有效,而且不會給伺服器帶來什麼特殊的負荷。但必須注意的是,Netscape Communicator對壓縮圖形的支援不佳,因此除非你能夠保證所有使用者都使用IE瀏覽器,否則你應該禁止壓縮JPEG和GIF圖形。一般地,對於所有其他檔案,這種壓縮都有效,但建議你針對各種瀏覽器都分別進行測試,特別是當你使用了特殊的外掛或者資料檢視器時這一點尤其重要。

使用前面介紹的各種技術,你能夠顯著地改善網站的效能表現,但應該注意的是:
PHP可能是、也可能不是效能瓶頸所在。務必仔細地觀察每一個和應用效能有關的因素,比如資料庫等。
單純使用本文技術只能在一定限度之內提高Web伺服器的效能。因此在歸咎於PHP以及它的快取之前,不妨看看是否應該升級伺服器以及是否可以引入負載平衡技術(後者需要較大的投資)。
不要低估內容壓縮的作用。雖然你在100 MB/s的LAN連線下看到Web應用響應非常迅速,但使用Modem連線的使用者不會,他們只會抱怨你那100 Kb的HTML頁面實在過於龐大。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10796304/viewspace-963252/,如需轉載,請註明出處,否則將追究法律責任。

相關文章