成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

CentOS FastCGI最大化性能揮其性能優(yōu)勢

系統(tǒng) Linux
Lighttpd 提供了很多其他Web服務(wù)器不具備的優(yōu)勢,可以最大化CentOS FastCGI的性能。現(xiàn)在Mongrel/Thin/ebb都利用了一些多線程或者事件IO機制來 提供并發(fā)性能,這是CentOS FastCGI所不具備的,但遺憾的是Rails框架是單線程的,最終還是必須單進程單線程來執(zhí)行Rails請求,所以這些并發(fā)優(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文件即可。

【編輯推薦】

  1. CentOS RoR應(yīng)用性能優(yōu)化的實戰(zhàn)經(jīng)驗
  2. CentOS WEB緩存服務(wù)器程序使用比較靈活
  3. CentOS Oracle測試運行使用root用戶修改
  4. CentOS NTFS安裝和配置支持所有符合POSIX標準的磁盤操作
  5. Linux CentOS常用命令的各種使用方法
責(zé)任編輯:佚名 來源: csdn
相關(guān)推薦

2009-01-05 19:07:03

服務(wù)器虛擬化虛擬機

2012-07-11 22:27:21

惠普服務(wù)網(wǎng)絡(luò)

2020-08-24 22:26:21

物聯(lián)網(wǎng)數(shù)據(jù)IOT

2024-12-20 09:45:09

C#Windows線程

2019-12-12 15:07:44

虛擬機性能效率

2010-03-19 09:31:52

虛擬化性能

2017-10-18 11:14:02

容器虛擬機云平臺

2020-04-22 14:03:30

云服務(wù)云計算企業(yè)

2023-03-02 09:57:03

2011-12-08 10:10:57

私有云

2012-06-13 09:35:41

存儲虛擬化

2011-07-20 13:23:48

SaaS云計算

2013-05-14 13:28:37

利用大數(shù)據(jù)價值

2020-07-26 18:55:31

存儲緩存IT

2022-03-10 16:39:51

Kyligence數(shù)據(jù)湖OLAP

2011-11-15 09:45:43

云計算云應(yīng)用

2016-04-12 10:02:22

2014-07-30 09:40:22

OracleERP云SaaS

2009-06-11 16:50:53

DCM數(shù)據(jù)中心虛擬化

2009-06-09 20:55:48

數(shù)據(jù)中心綠色IT虛擬化
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲字幕在线观看 | 中文字幕亚洲精品 | 国产精品一区久久久久 | 亚洲国产精品久久久久 | 亚洲不卡视频 | 91精品国产综合久久久动漫日韩 | 久久国产精品视频 | 亚洲欧美少妇 | 91天堂网| 99中文字幕| 国产精品久久久久无码av | 久久国产精品视频 | 日韩国产在线 | 在线免费观看黄色av | 欧美三区| 成人午夜激情 | 美女一级毛片 | 国产一区二区三区 | 午夜免费观看网站 | 成人在线免费电影 | 毛片综合 | 日本高清视频网站 | 一区二区精品电影 | 国产美女视频黄a视频免费 国产精品福利视频 | 色.com| www.五月婷婷.com | 91成人免费看 | 91社区视频| 欧美在线观看免费观看视频 | a级毛片免费高清视频 | 久久久久亚洲精品 | 日韩欧美在线观看视频网站 | 亚洲一区中文字幕 | 四虎永久免费黄色影片 | 一区二区三区精品在线视频 | 久久久久精 | 日本久久网 | 天天碰日日操 | 99免费在线| 精品国产一区二区三区观看不卡 | 国产视频久久 |