文/李鯤程
隨著網路的普及,網站已經滲透到了每個行業,但是由於目前專線費用讓許多企業和個人難以承受,所以共享頻寬成為許多網站的首選方案。費用雖然降低了但是一個新的問題很快就出現了,那就是共享頻寬的網速很慢,有時甚至讓人無法忍受。如何能讓自己的網站快起來,成為人們關心的問題,筆者結合親身實踐來講講軟辦法的一些實際應用,希望能夠對讀者有所幫助。
筆者採用的是Linux作業系統,Apache PHP的網站建置方法。
程式碼最佳化
通常要求程式設計師要有好的程式設計習慣,盡量減少冗餘程式碼的出現,目前也有許多工具能夠完成許多工具能夠完成一般的html文件,用來減少冗餘的減肥工具很多,而對於PHP程式來說這樣的工具就不太多了,但是Zend Technologies的Zend Optimizer是一款非常好的程式碼優化工具,可以免費從Zend Technologies的網站上獲得。 Zend Optimizer的使用方法也非常簡單,只要下載的ZendOptimizer-1[1].0.0-PHP_4.0.4- Linux_glibc21-i386.tar.gz檔案解壓縮,將其中的ZendOptimizer.so檔案拷貝到/usr/local /Zend/lib目錄下,然後修改php.ini文件,在最後加入以下幾行:
顯示說明Zend Optimizer工作正常
opyizer_. optimization_level=15
zend_extension="/usr/local/ Zend/lib/ ZendOptimizer.so"
『完成後重設程式?
Phpinfo();
?>
一般來說Zend Optimizer能將系統的效率提升30%~40%,這是用戶最關心的。
壓縮頁
HTTP1.1協定支援頁面壓縮傳送,也就是說伺服器把一個頁面壓縮傳送到客戶端,然後在客戶端將頁面解壓縮再顯示給客戶。在伺服器端有兩種傳輸方式,一種是頁面事先已經壓縮好了,傳送時只要將壓縮頁面傳送到客戶端就行,這種適用於靜態網頁多的情況,但是對於大多數站點,動態頁面比較多,這種方法不太適合,因為很多傳到客戶端的頁面其實是沒有的,是伺服器接到客戶端用戶請求動態產生的,所以就要求每生成一個動態頁面都要在傳到客戶端以前先打包壓縮。從PHP的4.0.4版以後,可以在php.ini檔案中增加一行設定“output_handler = ob_gzhandler”,這樣每個動態產生的頁面在傳送到客戶端之前都會進行壓縮,但是根據PHP官方網站的說明,這個參數不能與「zlib.output_compression = on」參數同時使用,因為容易造成PHP運作不正常,另外它只能壓縮PHP程式的動態產生的頁面,對於大量的靜態頁面尤其是影像檔案就不行了。但是mod_gzip模組為Apahe提供了將靜態頁面在傳給客戶端以前先壓縮的功能,它的壓縮比最大能到10,一般情況下可以到 3,也就是說網站的傳輸速率一下提高了三倍多。要想使用mod_gzip功能首先要下載mod_gzip.c或mod_gzip.so文件,如果下載的是.c文件還要用Apache帶的工具將它轉化為.so文件才能使用,方法是運行下面的命令:
-i -a mod_gzio.c
cp mod_foo.so/path/to/apache/libexec/mod_gzip.so
系統會在/path/to/apache/ etc/httpd.conf中自動啟動模組,如果下載的是.so檔案則要將該檔案拷貝到對應的目錄下,然後在httpd.conf檔中加入LoadModule gzip_module libexec/ mod_gzip.so,讓模組生效。需要注意兩點,第一,要想使用.so文件,Apache必須包含了mod_so模組(可以通過httpd -l命令來查詢該模組是否生效);第二,如果下載的是.so文件,它是與Apache的版本有關的,要注意下載的版本與自己使用的Apache是否一致,如果是.c檔就沒有這個問題。模組生效後也要對Apache進行對應的配置,需要在httpd.conf檔中加入一些參數:
mod_gzip_on Yes(模組是否生效)
mod_gzip_minimum_sizepize)
mod_gzip_maximum_file_size 0(最大壓縮檔案大小,0表示沒有限制)
mod_gzip_maximum_inm〜_size 60000(可佔用記憶體ude file "..gif102SINA>DOUBLE_QUOTATION (以gif結尾的檔案要壓縮傳送)
mod_gzip_item_include file ".txt102SINA>DOUBLE_QUOTATION
遨_gzip_pmm_g
mod_gzip_item_exclude file ".css102SINA>DOUBLE_QUOTATION
使用了壓縮模組後,當使用者造訪網站時會在日誌檔案中記錄對應的訊息,例如「mod_gzip :OK In:file_length Out:gzipfile_length」,表示該頁面傳輸中使用了gzip功能,輸入檔案、輸出文件大小都有說明。
檔案快取
這種方法通常是針對PHP、PERL等CGI程式而言的,因為這些程式有一個共同的特徵就是接到使用者的請求後不是馬上將結果回傳給用戶,而是經過解釋器解釋執行後將執行結果傳回給客戶,這段期間通常都要涉及資料庫的存取。這樣就會出現一個問題,當兩個使用者造訪同一個頁面時,系統將分別對兩個請求進行操作,但事實上這兩個操作可能是一模一樣的,這樣無形當中增加了系統的負擔。所以通常的解決辦法是在系統記憶體中開闢出一段空間,當使用者第一次造訪頁面後將執行結果存放在該記憶體中,當有使用者再一次造訪該頁面時,系統就會直接從記憶體中調出而不需要重新解釋執行,這段記憶體空間就叫快取。目前流行的快取管理程式有兩個,一個是FastCGI,另一個是Zend Technologies公司的Zend Cache。 FastCGI主要是針對Perl、C、C 等CGI腳本程序設計的,可以有效地利用內存作緩存,來自客戶端的請求都會被傳送到FastCGI應用服務程序,FastCGI處理用戶的請求後將結果返回給用戶。一般的CGI程序這時將結束進程自動退出,但是FastCGI進程繼續保持,這時它在接到新的用戶請求後不必建立新的進程,可以立即處理用戶請求,也就是說CGI程序建立進程順序執行然後退出,而FastCGI程式順序執行並永遠循環。
Zend Cache的管理介面
要使用FastCGI首先想使用FastCGIGI了,還要在http.conf檔案裡作設定:
AddHandler fastcgi-script .fcg .fcgi .fpl
〠工作了,以下是FastCGI程式設計手冊中的一段範例程式:
#!fcgi-savvy-perl
use FCGI; # > >
= 0;
# Response loop
🎜>
print "Content-type:text/html "; #程式執行
print "<head><title>FastCGI Demo Page (perl)</title>FastCGI Demo Page (perl)</title>FastCGI Demo Page (perl)</title></title> print "<h1>FastCGI Demo Page (perl)</h1> ";
print "This is coming from a print "Running on <EM >publish152.internal.sina.com.cn</EM> to <EM></EM><BR> ";
〠 >
}
FastCGI對Perl等CGI程式的功能非常強大,但是它對PHP程式確是無能為力的,而且需要在程式設計時增加內容,也就是說它需要一些人為的因素才能發揮作用。相較之下Zend Technologies公司的Zend Cache針對PHP的快取功能是很強大的,只要安裝了該軟體,程式設計師就像編寫其他PHP程式一樣,不需要增加程式碼,就可以實現快取功能,有利於系統升級,十分方便。它是一個付費軟體。它有快取功能並能透過圖形介面來管理,其中:Cache Control頁面,可以設定Zend Cache,顯示其目前狀態,也能啟動和停止Zend Cache功能;Scripts頁面,Zend Cache的內容,包括每個文件的狀態,還可以根據點擊次數和快取佔有大小選擇文件;Benchmark頁面,可以測試Zend Cache的快取效果,並以圖形方式給出顯示,它測試的是每秒鐘完成PHP請求的次數。
它的安裝、驗證方法與Zend Optimizer基本相同,這裡就不詳細說明了,有興趣的讀者可以參考用戶手冊,它的強大功能和便利的管理方法確實讓人心動。
以上是網站提速常見的幾種方法,對於不同的網站需要採用不同的手段,所對應的提速方案也不盡相同,但總體上不外乎是以上提到的三招,讀者可以根據自己的實際情況具體問題來具體分析。
注意:考慮到客戶端軟體的複雜性,因為有些客戶端軟體可能不支援某些特性,例如,mod_gzip對頁面進行壓縮,但是如果客戶端使用的是Netscape就不行,因為它不能把接收到的壓縮頁面解壓縮,導致頁面無法正常顯示。