作為流行的 Web 編程語言, php(做為現在的主流開發語言) 的最大優勢就是速度。 php(做為現在的主流開發語言)4 已經在這方面做的非常好了,你幾乎找不到比它更快的腳本編程語言了。但是如果你的應用負荷很大,而帶寬又比較小,或者有其他的瓶頸影響你的服務器性能,那麼,你不妨試試筆者為你開出的幾個藥方,看看是否靈驗。
一、代碼優化
一談到代碼優化,或許你想到的就是整齊明了的代碼,但是本文的意思卻不是在此,因為如果要尋求速度的話,就要對php(做為現在的主流開發語言) 源碼作相應的調整。一般說來就是去掉多余的注釋,讓代碼不可讀。但是這對於一個具有良好素養的程序員來說,簡直就是不可思議的。好在Zend Technologies 公司發布了 Zend 優化引擎可以幫助你做到這一點。它現在是免費的,但是你必須遵循 Zend Optimizer 許可。這個產品可以對引擎產生的中間代碼進行優化。
安裝這個引擎比較簡單,下載對應平台的版本以後,解開壓縮文件,然後在 php(做為現在的主流開發語言).ini 文件裡面加上下面兩行,重新啟動 Web 服務器,就搞定了。
zend_optimizer.optimization_level=15
zend_extension="/path/to/ZendOptimizer.so"
zend_loader.enable=Off
如果是 Win32 平台的話就應該是:
zend_optimizer.optimization_level=15
zend_extension_ts="C:path oendOptimizer.dll"
zend_loader.enable=Off
啊!沒有搞錯吧?怎麼是三行?其實第三行是可選的。因為看起來把 zend_loader 關掉能提高一點速度,因此值得把這第三行放到 php(做為現在的主流開發語言).ini 。需要注意的是,關掉的前提條件是你沒有在使用 Zend 加密程序。
二、緩沖
如果想要更進一步提升速度,我們就需要考慮采用緩沖技術了。有一些可選的解決方案,包括 Zend Cache (測試版本), APC, 以及 Afterburner Cache,另外還有 jpCache 等。
以上這些都是屬於緩沖模塊,他們把第一次對 .php(做為現在的主流開發語言) 文件請求產生的中間代碼存儲在 Web 服務器的內存中,然後對以後的請求返回“編譯好”的版本。因為這樣減少了磁盤讀寫,而且都在內存工作,所以這個過程能顯著提升應用性能,
現成的這類產品比較多,到底選擇誰呢?
Zend Cache 是一款不錯的商業產品,在第一次加載那些很大的 php(做為現在的主流開發語言) 頁面後,你會明顯感受到速度的提升,服務器會留出更多的資源。可惜這個產品是要花銀子的,但是在有些情形下,你可不要吝啬這些銀子。
Afterburner Cache 是 Bware Technologies 的產品,目前還處於 Beta 版本,看起來似乎和 Zend Cashe 一樣,但是它不能達到 Zend Cache 那樣好的效果,也不能和 Zend 優化引擎一起工作,但是它是免費的,所以我采用了這個模塊。
APC (Alternative php(做為現在的主流開發語言) Cache) 是 Community Connect 發布的又一個免費模塊,看起來似乎可以用於生產環境了。
Web 內容壓縮
對於日益擁擠的網絡來說,節約帶寬就像節約用水一樣是十分值得提倡的。根據IETF 標准,大多數浏覽器應該支持使用 gzip 壓縮的內容。也就是說你可以把用 gzip 壓縮的內容發送給浏覽器,浏覽器會透明的解壓數據。
mod_gzip 是 Remote Communications 公司推出的免費 apache(Unix平台最流行的WEB服務器平台) 模塊,能把靜態的Web 內容壓縮後發送給浏覽器。對於大多數靜態網頁來說,這個模塊十分合適。盡管
Remotecommunications 公司的人說這個模塊支持所有那些 mod_php(做為現在的主流開發語言), mod_perl,mod 什麼產生的動態內容,但是看起來還是不能工作,從 mod_gzip 的郵件列表來看,這個問題估計要到1.3.14.6f 才能解決。
如果要壓縮動態內容的話,我們可以采用class.gzip_encode.php(做為現在的主流開發語言),一個在腳本開始和結束時使用的 php(做為現在的主流開發語言) 類。對整個網站來說就是在 php(做為現在的主流開發語言).ini 的 auto_prepend 和 auto_append 中調用其中的函數。詳細你可以閱讀這個類的程序,這個程序注釋得很好,作者幾乎把什麼都告訴你了。不過使用之前,你的 php(做為現在的主流開發語言) 要編譯為支持 zlib。