在Zeus Web Server中安裝PHP語言支持
前言Zeus是一個運行于Unix下的非常優秀的Web Server,而PHP則是Unix下一個非常優秀的后臺腳本語言。 這兩個產品都是為非常喜歡的產品。為什么要寫這樣的一個Howto呢?是因為有大量的網站腳本是使用PHP開發的, 而這些程序運行在Zeus下也是一個非常好的選擇。寫這份文檔的目的在于能讓大家的PHP系統良好的運行于Zeus服務器上。 很早的時候我寫過一份整合Zeus和PHP的文章,它主要是講如何將PHP以FastCGI的本地調用方式來運行于Zeus中的, 本份Howto主要是來講如何讓PHP運行于Remote Responders方式下。因為這樣會比以local方式有更高的可擴展性和運行效率。
準備工作首先你應該Zeus安裝完成,也不會過多的講如何安裝和配置Zeus服務器本身,因為它的安裝和配置實在是太簡單了。如果有可能,最好將ports使用cvsup來升級一下。對于PHP依賴的相關軟件如果能提前裝,則從ports中安裝好。如MySQL、GD等。 安裝fastcgi注意,如果你安裝的PHP的版本會低于4.3.0哪么你才需要這步。新的PHP版本已經內置了fastcgi的庫。安裝fastcgi的方法非常的簡單:
root@~$cd /usr/ports/www/fcgi/root@/usr/ports/www/fcgi$make;make install;make clean編譯完成后我們可以在/usr/local/lib目錄中看到有libfcgi.a文件,同時在/usr/local/include目錄中會有fastcgi的所有頭文件。
編譯PHP編譯PHP可以使用通常的PHP編譯選項,下面是我使用的一個配置:
./configure --prefix=/usr/local/php --enable-fastcgi --with-mysql=/usr/local需要注意的是在PHP 4.3.0以上版本是使用的 --enable-fastcgi 選項,而PHP 4.3.0以前的版本應使用--with-fastcgi參數。 接著就是安裝PHP到系統中: makemake install編譯完成后,我們來測試一下安裝的php是能正確運行:
root@~$cd /usr/local/php/bin/root@/usr/local/php/bin$./php這時將進入php代碼輸入狀態,輸入
<? phpinfo(); ?>按ctrl-d運行后會見到php返回的信息則為正確。
配置FastCGI/PHP配置FastCGI 進入Zeus管理控制臺,打開需要配置的VHost配置。進入 API Support 中的 FastCGI 設置。在其中設置: Enabling Support for FastCGI Programs : Enable 在Configuring FastCGI Remote Responders中設置:Directory name : /usr/local/php/bin/php Location: Machine name: localhost Additional methods supported?:None 如果你的PHP應用不在本機,即使PHP沒有安裝在本機上,哪么也要設置 Docroot path 參數,它可以不存在于相應的目錄下。都設置完成后,點擊 Apply 按鈕。 配置PHP解析指向進入 URL Handling 中的 Handlers 設置。在 Adding a Handler 中設置以下參數:
File Extension : php Specify the path and filename of the handler, relative to the document root : /usr/local/php/bin/php HTTP 404 errors are handled by : The handler 注意,這里的 Specify the path and filename of the handler, relative to the document root 應和你上一步設置的 Directory name 值相同。都設置完成后,點擊 Apply 按鈕。所有的設置完成后使用vhost的commit功能將更 改提交并應用。這樣Zeus就設置好了Fastcgi和PHP的相關參數。
配置FastCGI/PHP啟動在Zeus的rc.d目錄中新建一個S05php的文件,內容為:
#!/bin/sh
# Script to start and stop the persistent PHP runner for FastCGI. # Please check paths before use.
# FastCGI PHP binary FPHPBIN=/usr/local/php/bin/php
# Location to place semaphore SEMFILE=/tmp/php.pid PHP_FCGI_CHILDREN=100 PHP_FCGI_MAX_REQUESTS=1000 export PHP_FCGI_CHILDREN export PHP_FCGI_MAX_REQUESTS
# This is Linux - use /proc to increase the local (ephemeral) port range #echo 1024 65000 > /proc/sys/net/ipv4/ip_local_port_range
if [ -z '$ZEUSHOME' ] then cd `dirname $0`/.. ZEUSHOME=`pwd` export ZEUSHOME fi
case '$1' in 'start')
if [ -e $SEMFILE ] then echo FastCGI PHP error: already running.Restart FastCGI PHP now kill `cat $SEMFILE` sleep 5 fi
if [ ! -x $FPHPBIN ] then echo FastCGI PHP error: please check that $FPHPBIN is executable and exists. exit 1 fi
echo Starting FastCGI PHP. $ZEUSHOME/web/bin/fcgirunner --user=65534 --group=65534 --pidfile=$SEMFILE 8002 $FPHPBIN
'stop') if [ -e $SEMFILE ] then echo Stopping FastCGI PHP. kill `cat $SEMFILE` rm $SEMFILE exit 0 fi 'restart') if [ -e $SEMFILE ] then echo Stopping FastCGI PHP. kill `cat $SEMFILE` sleep 5 fi echo Starting FastCGI PHP. $ZEUSHOME/web/bin/fcgirunner --user=65534 --group=65534 --pidfile=$SEMFILE 8002 $FPHPBIN *) echo 'usage: $0 {start|stop|restart}'
esac exit 1
在這個腳本中有以下內容需要視系統情況而 修改:
FPHPBIN=/usr/local/php/bin/php 應設置為php的路徑 SEMFILE=/tmp/php.pid 生成php.pid的路徑,該目錄必須可寫 PHP_FCGI_CHILDREN=100 php進程數目 PHP_FCGI_MAX_REQUESTS=1000 每個php的進程在退出前能夠響應的請求數,用于釋放資源 上面兩個根據硬件配置和網站訪問量設置,默認值是8,500。 一般來說 PHP_FCGI_CHILDREN > 訪問并發最大值+10PHP_FCGI_MAX_REQUESTS 如果設置過小,訪問量大的網站會因為php進程重起頻繁增加負荷。#echo 1024 65000 > /proc/sys/net/ipv4/ip_local_port_range 只用于linux --user=65534 --group=65534 為php進程運行的用戶和組,一般設置為nobody用戶和組FreeBSD是65534/65534,Linux是99/99 最后,將S05php文件設置為可執行文件,并將FastCGI/PHP運行起來:
chmod 755 S05php./S05php start一但啟動后就會在ps -ax列表中顯示出PHP_FCGI_CHILDREN+1個php進程。到你的vhost對應的Docroot目錄中建一個info.php文件,內容為: <?phpinfo();?>使用瀏覽器訪問vhost中的info.php文件,應該就可以看到PHP的info頁面了。
附注感謝CCF的壇主hunreal寫出的S05php腳本,它真的非常好用!如果還有什么想了解的可以到 Zeus PHP支持 頁得到更多的信息。
注:任何轉載或摘抄請注明文章出處(中文FreeBSD用戶組 http://www.cnfug.org)