亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区

當前位置:首頁 > 網站舊欄目 > 學習園地 > 設計軟件教程 > Lighttpd和RoR安裝配置的疑難解答

Lighttpd和RoR安裝配置的疑難解答
2010-01-14 23:32:31  作者:  來源:
在Linux平臺上安裝和配置Ruby on Rails詳解,講述了完整的安裝過程,本文提供相關的疑難解答

 

用Lighttpd還是Nginx/Mongrel? Top

現在Nginx/Mongrel的部署方式越來越受歡迎了,很多人置疑Lighttpd/FastCGI,并且現在也涌現了一些比Mongrel性能更好的例如Thin,ebb等ruby應用服務器,那Lighttpd/FastCGI真的過時了嗎?

大家有興趣可以看一下我這篇文章:RoR部署方案深度剖析,Lighttpd提供了很多其他Web服務器不具備的優勢,可以最大化FastCGI的性能。現在Mongrel/Thin/ebb都利用了一些多線程或者事件IO機制來提供并發性能,這是FastCGI所不具備的,但遺憾的是Rails框架是單線程的,最終還是必須單進程單線程來執行Rails請求,所以這些并發優勢無用武之地。但一些其他Ruby的Web框架例如camping,weavers已經開始支持ruby多線程,提供了比Rails好得多的性能,mongrel/ebb只有在這些web框架上面才能發揮其性能優勢。

所以只要你還是用Rails框架,Lighttpd/FastCGI就是性能最好的部署方案。

ubuntu安裝ruby缺少readline和zlib庫 Top

有些人的ubuntu安裝的庫不全,比方說缺少readline庫,缺少zlib庫,可能會導致自己手工編譯安裝ruby的失敗,那么就用apt-get先把庫安裝好。
 

編譯lighttpd的時候報告缺少pcre庫 Top

RHEL/CentOS用戶可能要用yum安裝一下pcre/pcre-devel這兩個庫,ubuntu用戶用apt-get安裝一下,Linux熟手也可以自己下載源代碼編譯安裝,Pcre是Perl兼容的正則表達式庫,Lighttpd的Rewrite功能需要它。

ubuntu操作系統執行rc.lighttpd腳本報錯 Top

如果你的Linux是ubuntu,那么需要自己創建啟動腳本,lighttpd官方wiki上面已經給出來一個該腳本示例,地址在:
http://redmine.lighttpd.net/wiki/1/ScriptsUbuntu

rc.lighttpd這個腳本是針對SuSE Linux寫的,此外還提供了一個rc.lighttpd.redhat是針對RedHat Linux寫的,你自己寫一個控制腳本,也不過是舉手之勞:

Java代碼 復制代碼
  1. #!/bin/sh   
  2.   
  3. case "$1" in    
  4.   start)            
  5.     /usr/local/lighttpd/sbin/lighttpd -f /etc/lighttpd/lighttpd.conf > /dev/null 2>&1  
  6.     ;;   
  7.   stop)    
  8.     killall lighttpd   
  9.     ;;   
  10.   restart)    
  11.    $0 stop   
  12.    sleep 1  
  13.    $0 start    
  14.    ;;   
  15.   *)    
  16.   echo "Usage: lighttpd.sh {start|stop|restart}"    
  17.   ;;    
  18. esac   
  19.   
  20. exit 0   


創建一個shell腳本,內容如上,chmod u+x lighttpd.sh,這個腳本就可以用來啟動關閉和重起lighttpd了
 

啟動Lighttpd的時候報錯,說XXX目錄找不到 Top

Lighttpd啟動之后默認情況下會寫access log,error log,如果你啟動了壓縮過程,還會把文件壓縮過的版本放在壓縮目錄下面,所以檢查一下你的lighttpd.conf配置文件,是不是這些目錄還沒有,或者路徑不對。

lighttpd可以啟動,但配了Rails就無法啟動 Top

如果無法啟動Rails,要學會自己看Lighttpd的error log和Rails項目的log目錄下面的fastcgi crash log,在這兩個log文件當中可以找到出錯原因。

其中一種常犯的錯誤是:Rails項目在Windows上面創建和開發,最后部署到Linux Server上面。這種情況下dispatch.fcgi這個腳本的ruby解析器路徑是 #!c:/ruby/bin/ruby.exe 這個路徑在Linux上面肯定是錯誤的,你可以改成#!/usr/bin/env ruby,或者干脆在Linux上面創建該Rails項目。

此外在windows上面創建的Rails項目,dispatch.fcgi沒有可執行權限,這也需要你在Linux上面先賦予可執行權限才行。你可以嘗試著手工運行該腳本cd public && ./dispatch.fcgi,看看是否可以運行。

啟動lighttpd報錯,說找不到socket路徑 Top

我在前面安裝文檔中給出來的配置內容如下:

Java代碼 復制代碼
  1. $HTTP["host"] == "www.xxx.com" {   
  2.  server.document-root = "/yourrails/public"  
  3.  server.error-handler-404 = "/dispatch.fcgi"  
  4.  fastcgi.server = (".fcgi" =>   
  5.     ("localhost" =>   
  6.       ("min-procs" => 10,   
  7.        "max-procs" => 10,   
  8.        "socket" => "/tmp/lighttpd/socket/rails.socket",   
  9.        "bin-path" => "/yourrails/public/dispatch.fcgi",   
  10.        "bin-environment" => ("RAILS_ENV" => "production")   
  11.       )   
  12.     )   
  13.  )   
  14. }  


就算照抄你要改改路徑吧?這個demo當中的socket路徑是/tmp/lighttpd/socket/rails.socket,那你要照抄,先檢查一下有沒有/tmp/lighttpd/sock目錄總是應該的吧?其實用啥路徑都無妨,關鍵就是別照抄,領會原理,根據自己的環境做相應的調整。
 

lighttpd正常啟動了,但訪問Rails出現404 Top

在lighttpd的虛擬域配置里面有一項
Java代碼 復制代碼
  1. server.error-handler-404 = "/dispatch.fcgi"  

意思是當lighttpd找不到URL對應的硬盤文件,就會調用Rails的dispatch.fcgi去處理該URL請求,這也是lighttpd訪問Rails的主要方式,其性能比URL轉發要快。如果你在配置文件里面忽略了這一行,lighttpd就會直接返回404錯誤,而不是交給Rails處理。
 

多次重起lighttpd以后fastcgi進程越來越多 Top

正常情況下,關閉Lighttpd以后,dispatch進程就會銷毀,但是在dispatch進程處理請求的時候關閉lighttpd,dispatch進程并不會馬上關閉,而是處理完畢當前請求,才會關閉掉。一些極端情況下,可能會導致dispatch進程一直不關閉,dispatch進程就會越來越多。解決辦法很簡單 killall -9 dispatch.fcgi,只管殺進程就好了。

lighttpd和FastCGI部署在不同的服務器怎么配置 Top

這種情況下,Lighttpd只是連接遠程服務器的TCP端口,而不負責啟動dispatch.fcgi進程,因此需要自己寫腳本啟動關閉dispatch.fcgi進程。lighttpd提供了一個spawn-fcgi的程序,可以用來啟動dispatch.fcgi進程,監聽TCP端口,你可以自己寫一個shell腳本來完成這個工作。另外spawn-fcgi還可以啟動dispatch.fcgi進程,創建本機的unix socket端口,和本機lighttpd通訊,例如:

例如:
Java代碼 復制代碼
  1. #!/bin/sh   
  2.   
  3. DISPATCH_PATH=/yourrailsapp/public/dispatch.fcgi   
  4. SOCKET_PATH=/tmp/lighttpd/socket   
  5. RAILS_ENV=production   
  6. export RAILS_ENV   
  7.   
  8. case "$1" in   
  9.   
  10.   start)   
  11.     for num in 0 1 2 3 4 5 6 7 8 9  
  12.     do  
  13.      /usr/local/lighttpd/bin/spawn-fcgi -f $DISPATCH_PATH -s $SOCKET_PATH/rails.socket-$num   
  14.     done   
  15.     ;;   
  16.   
  17.   stop)   
  18.     killall -9 dispatch.fcgi   
  19.     ;;   
  20.   
  21.   restart)   
  22.     $0 stop   
  23.     $0 start   
  24.     ;;   
  25.      
  26.   *)    
  27.     echo "Usage: dispatch.sh {start|stop|restart}"  
  28.     ;;   
  29.      
  30. esac   
  31.   
  32. exit 0  


執行 ./dispatch.sh start 將啟動10個dispatch.fcgi進程,在/tmp/lighttpd/sock目錄下面創建了10個unix socket文件,然后配置lighttpd去連接這10個socket文件:

Java代碼 復制代碼
  1. $HTTP["host"] =~ "www.xxx.com$" {   
  2.   server.document-root = "/yourrails/public"  
  3.   server.error-handler-404 = "/dispatch.fcgi"  
  4.   fastcgi.server = (".fcgi" =>   
  5.     (   
  6.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-0"),   
  7.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-1"),   
  8.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-2"),   
  9.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-3"),   
  10.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-4"),   
  11.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-5"),   
  12.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-6"),   
  13.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-7"),   
  14.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-8"),   
  15.       ("socket"=>"/tmp/lighttpd/socket/rails.socket-9")        
  16.     )   
  17.   )   
  18. }  


這樣做的好處是,每次重新部署應用,就不需要重起lighttpd了,只需要執行自己的dispatch.sh來重起dispatch.fcgi進程就可以了。同時也可以很好的解決上一個fastcgi進程堆積的問題。

如果遠程部署,配置方式是一樣的,就是lighttp連接的端口改為:

Java代碼 復制代碼
  1. ("host"=>"192.168.0.1, "port"=>3001),   
  2. ("host"=>"192.168.0.1, "port"=>3002),   
  3. ......  


dispatch.sh創建dispatch.fcgi進程的時候,使用 -t 參數創建tcp端口,而不是 -s 創建unix socket文件即可。
 

rails應用不在根目錄下,在子目錄下怎么配置 Top

例如你的rails應用必須使用某個網站的子目錄,如:http://www.xxx.com/myapp,那么lighttpd的配置要進行相應的修改:

Ruby代碼 復制代碼
  1. $HTTP["host"] == "www.xxx.com" {   
  2.   $HTTP["url"] =~ "^/myapp" {   
  3.     server.document-root = "/home/webroot/demo/public"  
  4.     alias.url = ("/myapp" => "/home/webroot/demo/public")   
  5.     server.error-handler-404 = "/myapp/dispatch.fcgi"  
  6.     fastcgi.server = ("/myapp/dispatch.fcgi" =>   
  7.         ("localhost" =>   
  8.           ("min-procs" => 1,   
  9.            "max-procs" => 10,   
  10.            "socket" => "/tmp/rails.socket",   
  11.            "check-local" => "disable",   
  12.            "bin-path" => "/home/webroot/demo/public/dispatch.fcgi",   
  13.            "bin-environment" => ("RAILS_ENV" => "production")   
  14.           )   
  15.         )   
  16.     )   
  17.   }   
  18. }  


1、要使用$HTTP["url"]去匹配你要訪問的子目錄,根據該子目錄進行特定的配置。這樣做的好處是,你可以在一個虛擬域下面部署多個rails應用,用子目錄分開就可以了。

2、使用alias.url來指定目錄別名,這可以保證你的靜態資源例如js,css,images訪問路徑是正常的

3、server.error-handler-404 要加上前綴: "/myapp/dispatch.fcgi"

4、在fastcgi配置里面,也要匹配該URL,特別注意,應該增加一項:"check-local" => "disable"的配置項

在進行如上配置以后,lighttpd已經可以正常的處理子目錄了,但是Rails的routes仍然無法正常工作,這需要我們修改Rails的配置文件config/environment.rb,在最后面添加如下代碼:

Ruby代碼 復制代碼
  1. class ActionController::AbstractRequest   
  2.   def relative_url_root   
  3.     '/myapp'  
  4.   end  
  5. end  


修改Rails處理URL請求的默認前綴。

好了,現在你可以打開瀏覽器測試一下了。
 

我使用了Rails的頁面緩存,卻不生效 Top

Rails的頁面緩存機制本質上是動態頁面靜態化技術,當你第一次訪問頁面的時候,在public目錄下面生成靜態頁面,后續同樣的請求,Web服務器將直接返回靜態頁面,不再轉發給Rails處理了。那么你如何讓Web服務器知道一個動態請求的URL應該去尋找相應的靜態頁面呢?這需要在lighttpd里面增加如下的配置:

C代碼 復制代碼
  1. url.rewrite = ( "^/$" => "index.html""^([^.]+)$" => "$1.html" )  


將所有URL請求統統重寫為后綴.html的靜態頁面請求,如果lighttpd找不到該靜態頁面,就會觸發404,轉發給Rails的dispatch.fcgi處理。但是如果你的Rails應用不使用Rails頁面緩存,則不要寫這個配置,以免不必要的增加lighttpd的負擔和增加處理請求的步驟。

安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢
亚洲人成网站在线播放2019 _日韩国产欧美精品_久久夜色精品国产欧美乱_在线视频福利一区
国产精品视频一区国模私拍| 日本免费一区二区三区视频观看| 亚洲一区二区三区加勒比| 欧美专区在线观看| 国产成人av影视| 亚洲熟妇无码一区二区三区导航| 国产综合免费视频| 中文字幕无码精品亚洲资源网久久| 99在线国产| 日韩精品免费播放| 国产精品久久亚洲7777| 国产欧洲精品视频| 亚洲一二三区在线| 久久理论片午夜琪琪电影网| 欧美最猛黑人xxxx黑人猛叫黄| 久久手机免费视频| 高清欧美性猛交| 水蜜桃亚洲一二三四在线| 日韩中文字幕免费视频| 黄色一级二级三级| 久久精品视频播放| 国语对白做受xxxxx在线中国| www.日韩av.com| 日韩av电影在线网| 国产极品jizzhd欧美| 少妇精品久久久久久久久久| 国产精品久久久久av福利动漫| 欧美 日韩 国产 激情| 精品福利影视| 国产成人精品久久亚洲高清不卡| 欧美性视频在线| 久久成人精品一区二区三区| 国产精品99久久久久久人| 欧美日韩高清免费| 亚洲欧美精品在线观看| 日韩视频免费在线观看| 99亚洲精品视频| 黄色www网站| 午夜精品一区二区在线观看的| 国产精品久久91| 久久精品国产一区二区三区不卡| 精品无人乱码一区二区三区的优势| 亚洲一区二区三区视频播放 | 久久av资源网站| 国产高清在线一区| 国产精品自拍视频| 欧美亚洲成人网| 视频在线一区二区三区| 欧美乱妇高清无乱码| 久久久久久久影院| 97伦理在线四区| 激情久久av| 日韩亚洲一区在线播放| 欧美激情乱人伦| 国产成人精品在线| 国产精品99久久久久久大便 | 国产精品第1页| 日韩一区二区久久久| 久久综合色视频| 国产精品香蕉在线观看| 美女日批免费视频| 日韩区国产区| 日本一本a高清免费不卡| 亚洲一区三区在线观看| 精品蜜桃传媒| 国产精品日韩精品| 日韩一区二区三区国产| 国产xxxxx视频| 久久视频在线观看中文字幕| 99在线免费视频观看| 麻豆av一区| 精品人妻大屁股白浆无码| 欧洲日韩成人av| 日本一区高清不卡| 亚洲国产日韩综合一区| 一区二区三区的久久的视频| 毛片精品免费在线观看| 欧美成人午夜剧场免费观看| 国产精品色午夜在线观看| 精品久久国产精品| zzijzzij亚洲日本成熟少妇| 久久久久久久激情| 久久99久久精品国产| 久久av一区二区三区漫画| 国产高清在线一区二区| 91国产在线免费观看| 91成人免费视频| 久久露脸国产精品| 国产成一区二区| 久久国产精品久久| 久久久久久中文字幕| 日韩中文字幕在线播放| 久久精品福利视频| 国产精品丝袜久久久久久消防器材| 久久久国产精品免费| 国产精品视频男人的天堂| 久久最新资源网| 国产精品久久久久久久久久| 精品国产一区二区三区四区在线观看| 欧美激情xxxx| 国产成+人+综合+亚洲欧美丁香花| 精品一区久久| 日本女人高潮视频| 亚洲人成网站在线播放2019| 九九久久国产精品| 国产精品久久久91| 久久久精品国产| 色天天综合狠狠色| 久久久久久久久久久久久久久久av| 国产极品尤物在线| 97免费视频在线播放| 国产精品午夜av在线| 国产剧情日韩欧美| 国产自产在线视频| 精品网站在线看| 免费日韩中文字幕| 激情五月宗合网| 国内精品模特av私拍在线观看| 欧美精品一区二区三区免费播放| 奇米一区二区三区四区久久| 欧美一区二区三区精品电影| 岛国一区二区三区高清视频| 日韩一级片一区二区| 日韩一区国产在线观看| 亚洲va码欧洲m码| 午夜美女久久久久爽久久| 亚洲www视频| 色欲色香天天天综合网www| 视频一区三区| 99在线看视频| 国产一区二区中文字幕免费看| av在线播放亚洲| 日韩中文字幕第一页| 久久久久久18| 热久久这里只有精品| 国产欧美日韩精品专区| 久久综合伊人77777麻豆| 国产精品美女久久久久av超清 | 91久久精品国产| 久久精品中文字幕| 最新av网址在线观看| 日本十八禁视频无遮挡| 免费看a级黄色片| 久久综合婷婷综合| 久久亚洲电影天堂| 视频在线精品一区| 国产午夜精品在线| 国产成人成网站在线播放青青| 国产精品精品久久久| 色噜噜色狠狠狠狠狠综合色一| 激情小视频网站| 国产精品9999| 精品国产91亚洲一区二区三区www| 日本久久久精品视频| 国产精品午夜av在线| 日韩视频―中文字幕| 亚洲自拍欧美色图| 黄色av网址在线播放| 久久久com| 在线一区日本视频| 黄页网站大全在线观看| 久久琪琪电影院| 欧美精品video| 欧美日韩亚洲一| 国产福利不卡| 在线免费观看一区二区三区| 男女超爽视频免费播放| 国产黄页在线观看| 一区二区不卡在线观看| 国模吧一区二区| 久久99久久99精品蜜柚传媒| 在线观看一区二区三区三州| 女女同性女同一区二区三区按摩| 国产精品97在线| 伊人久久大香线蕉成人综合网| 精品亚洲欧美日韩| 国产精品丝袜久久久久久不卡| 欧美一区二区福利| 97人人模人人爽人人喊中文字| 国产精品电影网| 欧美国产一二三区| 久操网在线观看| 欧美一级视频在线观看| 91九色视频在线| 中文字幕日韩精品久久| 国产人妻777人伦精品hd| 国产精品视频久久| 欧洲精品在线一区| 久久99精品久久久久子伦| 亚洲www在线| 91av视频在线免费观看| 亚洲专区国产精品| 国产一级特黄a大片99| 国产精品果冻传媒潘| 欧美大陆一区二区| 久久久国产视频| 女女同性女同一区二区三区91 | 欧美日韩亚洲一| 国产精品日韩电影| 欧美国产视频在线观看|