CentOS FastCGI最大化性能揮其性能優(yōu)勢
對大家推薦很好使用的CentOS FastCGI系統(tǒng),像讓大家對CentOS FastCGI系統(tǒng)有所了解,然后對CentOS FastCGI系統(tǒng)全面講解介紹,希望對大家有用。
一、到底我應(yīng)該用Lighttpd,還是Nginx/Mongrel?
現(xiàn)在Nginx/Mongrel的部署方式越來越受歡迎了,很多人置疑Lighttpd/FastCGI,并且現(xiàn)在也涌現(xiàn)了一些比Mongrel性能更好的例如Thin,ebb等ruby應(yīng)用服務(wù)器,那Lighttpd/FastCGI真的過時了嗎?
Lighttpd 提供了很多其他Web服務(wù)器不具備的優(yōu)勢,可以最大化CentOS FastCGI的性能。現(xiàn)在Mongrel/Thin/ebb都利用了一些多線程或者事件IO機制來 提供并發(fā)性能,這是CentOS FastCGI所不具備的,但遺憾的是Rails框架是單線程的,最終還是必須單進程單線程來執(zhí)行Rails請求,所以這些并發(fā)優(yōu)勢無 用武之地。但一些其他Ruby的Web框架例如camping,weavers已經(jīng)開始支持ruby多線程,提供了比Rails好得多的性 能,mongrel/ebb只有在這些web框架上面才能發(fā)揮其性能優(yōu)勢。
有人會問,Rails會不會改成多線程?我認為不可能:一來Rails的多進程被證明是一種古老的、但是高可靠性、高擴展性的部署方式,沒有改的必要性;二來真要改成多線程,改動實在太大了,整個底層框架都要改。
所以只要你還是用Rails框架,Lighttpd/CentOS FastCGI就是性能最好的部署方案。
二、ubuntu Linux安裝ruby碰到的缺少readline,zlib庫的問題?
有些人的ubuntu安裝的庫不全,比方說缺少readline庫,缺少zlib庫,可能會導(dǎo)致自己手工編譯安裝ruby的失敗,那么就用apt-get先把庫安裝好。
三、Lighttpd安裝遇到的缺少pcre庫的問題?
RHEL/CentOS用戶可能要用yum安裝一下pcre/pcre-devel這兩個庫,ubuntu用戶用apt-get安裝一下,Linux熟手 也可以自己下載源代碼編譯安裝,Pcre是Perl兼容的正則表達式庫,Lighttpd的Rewrite功能需要它。
四、Lighttpd配置過程當中遇到的種種問題?
1、我用的是ubuntu,你說的控制腳本rc.lighttpd我跑不了,執(zhí)行就會報錯
rc.lighttpd這個腳本是針對SuSE Linux寫的,此外還提供了一個rc.lighttpd.redhat是針對RedHat Linux寫的,沒有針對ubuntu的版本,但是你自己寫一個控制腳本,也不過是舉手之勞:
Java代碼 #!/bin/sh case "$1" in start) /usr/local/lighttpd/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf > /dev/null 2>&1 ;; stop) killall lighttpd ;; restart) $0 stop sleep 1 $0 start ;; *) echo "Usage: lighttpd.sh {start|stop|restart}" ;; esac exit 0 view plaincopy to clipboardprint?
#!/bin/sh case "$1" in start) /usr/local/lighttpd/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf > /dev/null 2>&1 ;; stop) killall lighttpd ;; restart) $0 stop sleep
1 $0 start ;; *) echo "Usage: lighttpd.sh {start|stop|restart}" ;; esac exit 0
創(chuàng)建一個shell腳本,內(nèi)容如上,chmod u+x lighttpd.sh,這個腳本就可以用來啟動關(guān)閉和重起lighttpd了
2、啟動Lighttpd的時候報錯,說XXX目錄找不到
Lighttpd啟動之后默認情況下會寫access log,error log,如果你啟動了壓縮過程,還會把文件壓縮過的版本放在壓縮目錄下面,所以檢查一下你的lighttpd.conf配置文件,是不是這些目錄還沒有,或者路徑不對。
3、啟動lighttpd可以訪問,但如果配置了Rails,就無法啟動
如果無法啟動,要學(xué)會自己看Lighttpd的error log和Rails項目的log目錄下面的CentOS FastCGIcrash log,在這兩個log文件當中可以找到出錯原因。其中一種常犯的錯誤是:Rails項目在Windows上面創(chuàng)建和開發(fā),最后部署到Linux Server上面。這種情況下dispatch.fcgi這個腳本的ruby解析器路徑是 #!c:/ruby/bin/ruby.exe 這個路徑在Linux上面肯定是錯誤的,你可以改成#!/usr/bin/env ruby,或者干脆在Linux上面創(chuàng)建該Rails項目。此外在windows上面創(chuàng)建的Rails項目,dispatch.fcgi沒有可執(zhí)行權(quán)限, 這也需要你在Linux上面先賦予可執(zhí)行權(quán)限才行。你可以嘗試著手工運行該腳本cd public && ./dispatch.fcgi,看看是否可以運行。
4、啟動lighttpd報錯,說找不到socket路徑
我在前面安裝文檔中給出來的配置內(nèi)容如下:
Java代碼 $HTTP["host"] == "www.xxx.com" { server.document-root = "/yourrails/public" server.error-handler-404 = "/dispatch.fcgi" CentOS FastCGI.server = (".fcgi" =>
("localhost" =>
("min-procs" => 10,
"max-procs" => 10,
"socket" => "/tmp/lighttpd/socket/rails.socket",
"bin-path" => "/yourrails/public/dispatch.fcgi",
"bin-environment" => ("RAILS_ENV" => "production")
view plaincopy to clipboardprint?
$HTTP["host"] == "www.xxx.com" { server.document-root = "/yourrails/public" server.error-handler-404 = "/dispatch.fcgi" fastcgi.server = (".fcgi" => ("localhost" => ("min-procs" => 10, "max-procs" => 10, "socket" => "/tmp/lighttpd/socket/rails.socket", "bin-path" => "/yourrails/public/dispatch.fcgi", "bin-environment" => ("RAILS_ENV" => "production") ) ) ) }
就算照抄你要改改路徑吧?這個demo當中的socket路徑是/tmp/lighttpd/socket/rails.socket,那你要照 抄,先檢查一下有沒有/tmp/lighttpd/sock目錄總是應(yīng)該的吧?其實用啥路徑都無妨,關(guān)鍵就是別照抄,領(lǐng)會原理,根據(jù)自己的環(huán)境做相應(yīng)的調(diào) 整。
5、lighttpd可以啟動,但是訪問Rails應(yīng)用出現(xiàn)404錯誤,找不到頁面在lighttpd的虛擬域配置里面有一項 Java代碼 server.error-handler-404 = "/dispatch.fcgi" view plaincopy to clipboardprint?
server.error-handler-404 = "/dispatch.fcgi"
意思是當lighttpd找不到URL對應(yīng)的硬盤文件,就會調(diào)用Rails的dispatch.fcgi去處理該URL請求,這也是 lighttpd訪問Rails的主要方式,其性能比URL轉(zhuǎn)發(fā)要快。如果你在配置文件里面忽略了這一行,lighttpd就會直接返回404錯誤,而不 是交給Rails處理。
6、重起lighttpd以后,CentOS FastCGI進程不關(guān)閉,導(dǎo)致多次重起lighttpd之后,CentOS FastCGI進程堆積越來越多?
正常情況下,關(guān)閉Lighttpd以后,dispatch進程就會銷毀,但是在dispatch進程處理請求的時候關(guān)閉 lighttpd,dispatch進程并不會馬上關(guān)閉,而是處理完畢當前請求,才會關(guān)閉掉。一些極端情況下,可能會導(dǎo)致dispatch進程一直不關(guān) 閉,dispatch進程就會越來越多。解決辦法很簡單 killall -9 dispatch.fcgi,只管殺進程就好了。
7、我的lighttpd和CentOS FastCGI部署在不同的服務(wù)器,怎么配置呢?
這種情況下,Lighttpd只是連接遠程服務(wù)器的TCP端口,而不負責(zé)啟動dispatch.fcgi進程,因此需要自己寫腳本啟動關(guān)閉 dispatch.fcgi進程。lighttpd提供了一個spawn-fcgi的程序,可以用來啟動dispatch.fcgi進程,監(jiān)聽TCP端 口,你可以自己寫一個shell腳本來完成這個工作。另外spawn-fcgi還可以啟動dispatch.fcgi進程,創(chuàng)建本機的unix socket端口,和本機lighttpd通訊,例如:
例如: Java代碼 #!/bin/sh
DISPATCH_PATH=/yourrailsapp/public/dispatch.fcgi
SOCKET_PATH=/tmp/lighttpd/socket
RAILS_ENV=production
export RAILS_ENV
case "$1" in start)
for num in 0 1 2 3 4 5 6 7 8 9 do /usr/local/lighttpd/bin/spawn-fcgi -f $DISPATCH_PATH -s $SOCKET_PATH/rails.socket-$num done ;; stop) killall -9 dispatch.fcgi
;; restart) $0 stop $0 start ;; *) echo "Usage: dispatch.sh {start|stop|restart}" ;; esac exit 0
view plaincopy to clipboardprint?#!/bin/sh DISPATCH_PATH=/yourrailsapp/public/dispatch.fcgi SOCKET_PATH=/tmp/lighttpd/socket RAILS_ENV=production export RAILS_ENV case "$1" in start) for num in 0 1 2 3 4 5 6 7 8 9 do /usr/local/lighttpd/bin/spawn-fcgi -f $DISPATCH_PATH -s $SOCKET_PATH/rails.socket-$num done ;; stop) killall -9 dispatch.fcgi ;; restart) $0 stop $0 start ;; *) echo "Usage: dispatch.sh {start|stop|restart}" ;; esac exit 0
執(zhí)行 ./dispatch.sh start 將啟動10個dispatch.fcgi進程,在/tmp/lighttpd/sock目錄下面創(chuàng)建了10個unix socket文件,然后配置lighttpd去連接這10個socket文件:
Java代碼 $HTTP["host"] =~ "www.xxx.com$" { server.document-root = "/yourrails/public" server.error-handler-404 = "/dispatch.fcgi" CentOS FastCGI.server = (".fcgi" => (
("socket"=>"/tmp/lighttpd/socket/rails.socket-0"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-1"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-2"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-3"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-4"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-5"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-6"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-7"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-8"),
("socket"=>"/tmp/lighttpd/socket/rails.socket-9")
view plaincopy to clipboardprint?
$HTTP["host"] =~ "www.xxx.com___FCKpd___4quot; { server.document-root = "/yourrails/public" server.error-handler-404 = "/dispatch.fcgi" fastcgi.server = (".fcgi" => ( ("socket"=>"/tmp/lighttpd/socket/rails.socket-0"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-1"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-2"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-3"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-4"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-5"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-6"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-7"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-8"), ("socket"=>"/tmp/lighttpd/socket/rails.socket-9") ) ) }
這樣做的好處是,每次重新部署應(yīng)用,就不需要重起lighttpd了,只需要執(zhí)行自己的dispatch.sh來重起dispatch.fcgi進程就可以了。同時也可以很好的解決上一個CentOS FastCGI進程堆積的問題。
如果遠程部署,配置方式是一樣的,就是lighttp連接的端口改為: Java代碼
("host"=>"192.168.0.1, "port"=>3001),
("host"=>"192.168.0.1, "port"=>3002),
view plaincopy to clipboardprint?("host"=>"192.168.0.1, "port"=>3001), ("host"=>"192.168.0.1, "port"=>3002), ...... dispatch.sh創(chuàng)建dispatch.fcgi進程的時候,使用 -t 參數(shù)創(chuàng)建tcp端口,而不是 -s 創(chuàng)建unix socket文件即可。
【編輯推薦】