久久亚洲精品成人_国产精品欧美综合亚洲_亚洲va天堂va欧美ⅴa在线_91色视频在线观看_久久影院亚洲_一级黄色片播放_日韩av在线一区_精品一区二区在线看_老头吃奶性行交视频_日韩免费高清视频_天天操天天爽天天干_日本欧美在线视频

首頁 > 編程 > Ruby > 正文

提升Ruby on Rails性能的幾個解決方案

2020-10-29 19:40:46
字體:
來源:轉載
供稿:網友

簡介

Ruby On Rails 框架自它提出之日起就受到廣泛關注,在“不要重復自己”,“約定優于配置”等思想的指導下,Rails 帶給 Web 開發者的是極高的開發效率。 ActiveRecord 的靈活讓你再也不用配置繁瑣的 Hibernate 即可實現非常易用的持久化,Github 和 Rubygems 上豐富多樣的 Rails 插件是 Rails 開發高效率的又一有力保障。Rails 是一個真正徹底的 MVC(Model-View-Controller) 框架,Rails 清楚地將你的模型的代碼與你的控制器的應用邏輯從 View 代碼中分離出來。Rails 開發人員很少或者可能從未遇到過某些代碼該放于哪一層的困擾,在 Rails 的世界中,你的代碼的職責很清楚的被定位,你可以輕松的決定出它們應該位于哪一層。Rails1.2 之后的版本開始支持 Rest Service,通過這些內嵌的特別,你在開發你 Web 應用,展現給用戶 HTML 的頁面的同時,幾乎不費吹灰之力,就可又提供基于 Rest API 的 Web Service,另外,你也可以方便的像使用基本數據的 Model 一樣的去消費第三方提供的基于 Rest API 的 Web Service。

通過搜索引擎,你可以找到很多類似于用 Ruby On Rails 十五分鐘創建 Blog 系統等類似的使用 Rails 進行快速開發的文章。 Ruby On Rails 對于敏捷開發過程的也是非常友好,在 Rails 框架中集成了 Unit Test, Function Test 對你的 Model 和應用邏輯進行測試。通過這些,你不需要再安裝任何插件或者程序庫便可方便的進行測試驅動開發,通過 Watir 的支持,你可以輕松的用 Ruby 代碼實現基于瀏覽器的自動測試。 另外,在 Rspec 等插件的支持下,你甚至可以進行行為驅動開發(Behaviour Driven Development),讓你的測試代碼變得更加有意義,也更加容易被客戶所接受。

雖然 Rails 的優點你可以一下子列出很多,你也可能會拿出用 Java/Hibernate/Spring/Struts 和 Ruby On Rails 開發同樣功能 Web 應用程序的代碼行比較來舉例,或者提供進行 Java/Hibernate/Spring/Struts 和 Ruby On Rails 開發所需要接受的培訓資料的書籍的對比照片來舉例,但我們都不可避免的會面對可伸縮性(Scalability)的問題。很多 Web 應用會面對大量的用戶群,這樣的應用會遇到很大的并發帶來的性能的考驗。 Rails 在這一點上,并沒有讓所有人信服,依然有很多的系統架構師和工程師對 Rails 是否適用于開發高負載高并發的 Web 應用持懷疑的態度。但不可否認,隨著 twitter, friends for sale,basecamp 這類大負載量的應用的出現,Rails 也越來越被認識是可擴展的,這些成熟的應用也告訴我們,開發出同時處理數百萬用戶請求的 Rails 應用是可能的。Ruby On Rails 框架在可伸縮性上為人詬病無非集中于以下幾點,Ruby 語言本身性能問題,Ruby On Rails 缺少成熟的高性能的應用服務器,對數據庫擴展的支持,互聯網上缺乏可熟可靠的網絡提供商等等。 本文將從這些點出發,介紹具可伸縮性的 Rails 應用程序的部署架構,以及開發高性能的 Rails 應用程序的一些比較好的具體實踐。

通常的 Web2.0 應用,特別是高負載的應用,除了 Web 和應用服務器選擇 , 負載均衡這類部署需要面對的問題之外,通常還必須得面對后臺任務,高性能全文搜索這些開發上的問題,這些在 Java 或者 PHP 這些比較成熟的開發環境里面都有比較成熟的方案,開發和架構人員通常都會有多種選擇,結合具體應用做出架構設計。在新興的 Rails 社區,這些還并不完善和成熟,本文將介紹一些高性能可伸縮的 Rails 應用程序的開發和部署的具體實踐,針對通常 Web 2.0 網站所遇到的具體問題做出分析和解決方案,旨在給 Rails 開發者提供具體的參考。本文將介紹的內容可以用下圖來綜合表示:
圖 1. 本文總體結構

2015422165036728.gif (516×360)

使用 Nginx+Passenger 來替代 Apache+Mongrel 來部署 Rails 應用

事實上,進行 Rails 部署可以描述得非常簡單,我們需要一些機器配置我們的環境,為了性能和成本,我們理所當然選用 Linux 系列的服務器,可選的有 CentOS,Debian, Ubuntu Server 等。本文的所有程序,命令以及代碼如非特別說明,都默認是以 Linux 為基本環境的。 然后我們需要數據庫存儲我們的數據,我們可以選用免費的 Mysql,然后我們便開始開發我們的 Web 應用的 Rails 代碼,部署時,我們需要支持 Ruby On Rails 的應用服務器讓我們的 Rails 代碼跑起來,這可能是 Rails 自帶的 Webrick,當然這個可能性極小,也可能是 FastCGI, 或者是 Mongrel,Thin, Passenger 等等,然后我們通過 Apache,Nginx,Lighttpd,HAProxy 之類的 Web 服務器訪問我們的應用服務器,這個訪問可以直接通過 HTTP 協議,也可以是 FastCGI,或者是自定義的其它協議,如此這般,我們便可以通過瀏覽器訪問我們的應用程序了。如下圖所示,這便是通常的 Rails 應用程序部署結構。
圖 2. Rails 應用程序部署結構

2015422165112782.gif (224×184)

對于前端的 Web Server,Apache 是事實上的工業標準,在 Web 服務器市場,是占有率最高的,全球大量的網站采用 Apache 來部署他們的應用,Apache 是一款成熟穩定的 Web 服務器,功能非常強大,提供對幾乎所有 Web 開發語言和框架的擴展支持,在對 Rails 框架的支持上,我們可以采用 mod_fcgid 模塊,通過 FastCGI 協議與 Rails 進程通訊。或者利用 mod_proxy_balancer 對后端的獨立的 Rails 服務器如 Thin Cluster,Mongrel Cluster 或者 Apach/Nginx+Passenger 進行 HTTP 分發。但 Apache 作為一個通用的服務器,在性能上和一些輕量型的 Web 服務器相差甚遠。Apache 的 mod_proxy_balancer 模塊的分發性能不高,比 Nginx 或者 HAproxy 都相差很多,另外,Apache 目前并不支持 Event(事件)模型,它僅支持 Prefork(進程)模式和 Worker(線程)模式,每處理一個鏈接,就需要創建一個進程或線程,而一些輕量級 Web 服務器如 Nginx 和 Lighttpd,則都很好地利用內核的事件機制提高性能,極大減少線程或進程數量,降低系統負載。

Nginx 是一個輕量級的高效快速的 Web 服務器,它作為 HTTP 服務器和反向代理服務器時都具有很高的性能。Nginx 可以在大多數 Unix like OS 上編譯運行,并有 Windows 移植版。 Nginx 選擇了 Epoll 和 Kqueue 作為開發模型,它能夠支持高達 50,000 個并發連接數的響應,可以在內部直接支持 Rails 和 PHP 程序對外進行服務。另外,Nginx 作為負載均衡服務器,也可以支持作為 HTTP 代理服務器對外進行服務 , Nginx 不論是系統資源開銷還是 CPU 使用效率都比 Apache 要好很多。當你打開 Nginx 官方網站,你會發現一個如此知名的 Web 服務器產品的官方主頁竟然如此簡單,其實,Nginx 本身就是一個安裝非常簡單,配置文件非常簡潔,甚至可以在配置文件中使用 Perl 語法。

在處理靜態文件上, Apache 和 Nginx 都可以勝任。但對于應用服務器或者是前端的負載均衡服務器,我們推薦 Nginx 而不是相對 Nginx 較為重量級的 Apache。

對于應用服務器,Mongrel 一度是最流行的部署方式,它的 HTTP 協議的解析部分是用 C 語言編寫的,效率上有所保證。Mongrel 使用了 Ruby 的用戶線程機制來實現多線程并發 , 但是 Ruby 并不是本地線程 ,Rails 也不是線程安全的,因此 Mongrel 在執行 Rails 代碼的過程中,完全是加鎖的狀態,那和單進程其實也沒有太大差別。所有我們在使用 Mongrel 來部署 Rails 應用程序時,一般是在后臺啟動一個 mongrel_cluster 來啟動多個 Mongrel 進程,如我們在 mongrel_cluster.yml 中進行如下配置可以在 8000~8009 端口啟動 10 個 Mongrel 進程。
清單 1. Mongrel_cluster.yml 配置

 ---  cwd: /var/www/test_app  log_file: log/Mongrel.log  port: "8000" environment: production  debug: false  pid_file: log/mongrel.pid  servers: 10

這樣的部署方式實際上也限制了 Mongrel 處理大并發應用的能力,在處理大數據量請求的時候,Mongrel 進程經常被掛過,但并發數一多,就會出現所有的 Mongrel 進都會被掛過的情況,這樣前端的服務器便得不到返回,整個 Web 應用就陷入癱瘓。所以,Mongrel 并沒有被廣泛采用,很多網站寧愿堅持使用最古老的 FastCGI 的部署方式也不使用 Mongrel 來部署應用,而且 Mongrel 也停止更新很久,Mongrel 的開發者已完全不再進行 Mongrel 的開發了。所以,Mongrel 并不是現在最推薦的 Rails 應用服務器。

Passenger 是類似于 mod_php 的 Rails 運行環境,而不是 Mongrel 那樣是獨立的 Http 服務器。Passenger 對目前主流的 apache 和 Nginx 兩大 Web 服務器都有支持。Passenger 使用起來極其方便,而且它具有較高的性能,從 Passenger 官方網站公布的測試結果來看,Passenger 的性能要優于 Mongrel 服務器,目前來說,Passenger 無疑是最好的選擇。Passenger 繼承了 Rails"不重復自己"的慣例,通過 Passenger 部署應用程序,你僅僅需要將 Rails 項目程序文件上傳到目標服務器,甚至都不需要重啟服務器,非常簡單。

要在 Nginx 環境下安裝運行 Passenger, 你僅僅需要如下操作:
清單 2. 安裝 Passenger

 gem install passenger  Passenger-install-nginx-module

下面的代碼展示了在 Nginx 上配置 Passenger:
清單 3. 在 Nginx 上配置 Passenger

 http {   ...   server {     listen 80;     server_name www.test.com;     root /var/www/test/public;     passenger_enabled on;   }   ...  }

通過 Nginx+Passenger 構建 Ruby On Rails 的應用服務器可以得到顯著的性能提升,同時,還可以采用 Ruby Enterprise Edition 來提升 Ruby 本身的性能。這個版本也是由 Phusion 開發的,采用 copy-on-write 的垃圾回收策略,并使用 tcmalloc 來改善內存分配,他們的網站公布的數據,使用 Ruby Enterprise Edition 能比普通的 Ruby 版本減少 33% 的內存消耗。

Nginx+Passenger 就部署在一臺機器上的應用服務器,但并發過大時,一臺機器并不足以來提供這樣的處理能力,這個時候,一般會做負載均衡,這和通常的負載均衡策略并無二異,Nginx 在使用反向代理來實現負載均衡的能力上要強于 Apache 的反向代理模塊,我們可以在多臺 Nginx+Passenger 的前端可以再增加一臺 Nginx 的 Web 服務器。甚至為了更強的處理能力,我們也可以采用 LVS 來進行負載均衡。

使用 Starling 和 Workling 去異步執行 Rails 后臺任務

在進行 Web 應用開發時,每個 Web 請求都需要迅速的得到返回,這時候有些計算量比較大的操作可以放在后臺去異步執行,比如大量的數據更新操作,只需要在 Web 應用中進行觸發,然后在后臺進行執行。而有些操作則需要定期去執行,比如數據的備份,一些數據的統計分析,圖片的處理,郵件的發送等等。這些操作如果放在 Web 應用中即時返回顯然是不合適的,而且也會帶來機器的負載很嚴重,對于 Rails 應用程序來說,除了影響用戶體驗,這樣的操作還會阻塞 Rails 服務器實例,從而帶來整體性能的下降。對于這類操作,我們可以使用一個任務隊列,將需要執行的操作依次入隊,然后在后臺再啟動進程進隊列中取出這些任務,并執行,隊列可以使用數據庫,Memcached, ActiveMQ 或者 Amazon SQS 來實現,而后端進程則可以使用 Rails 里面的 cronjob+script/runner 或者 BackgrounDRb 等等來操作。這里要介紹的解決方案則是采用 twitter 開發人員貢獻出來的采用 Memcache 協議的 Starling 消息隊列和 Workling 插件來進行實現。

Starling 是 twitter 開發團隊從 twitter 項目抽象出來開源的 Rails 插件,雖然說 Starling 并不完全就是 twitter 的線上版本所用的插件,但我們也可以足以相信 Starling 的性能和應對高并發的處理能力。類似的插件還有 backgroundrb,background job, background_fu。backgroundrb 是使用 drb 實現隊列的消息傳遞,但它還有一個問題,更新隊列的時候,backgroundrb 使用的是悲觀鎖,在大訪問量的情況下,這種情況是不容允許的。 background job 和 background_fu 則是基于數據庫的消息隊列,在大負載量的情況下數據庫的性能也不容易得到保證。而 Starling 是基于 Memcached 協議的消息隊列,效率更高,也更容易伸縮,通常你可以在每臺應用服務器上都運行一個 Starling 服務器,并在同一臺機器或者其它機器上去運行后臺程序與之交互。

我們通過如下命令來安裝 Starling:
清單 4. 安裝 Starling

 gem sources -a http://gems.github.com/  sudo gem install starling-starling  mkdir /var/spool/starling

在讀取 Starling Server 時,我們需要 memcache-client,這個 gem 的 1.5.0 版本有一些問題,在 fiveruns-memcache-client 得到修正,這個 fiveruns-memcache-client gem 在 starling-starling gem 中是作為依賴項自動安裝的。

安裝完 Starling 之后,使用 sudo Starling -d -p 15151 這個命令來啟動它,啟動時用 -p 參數來指定所要使用的端口,一般加 -d 參數使它以 daemon 方式在后臺運行:

為了明白 Starling 的機制和 Starling 究竟做了哪些工作,在啟動了 Starling 之后,我們可以使用我們打開 irb 下面的程序來進行簡單的測試:

進行簡單的測試
清單 5. 測試 Starling

 >> require 'starling' => true  >> Starling = Starling.new('127.0.0.1:15151)  => MemCache: 1 servers, ns: nil, ro: false  >> Starling.set('test_queue', 123)  => nil  >> loop { puts Starling.get('test_queue'); sleep 1 }  123  nil  nil  ...

這里我們可以看到確實啟動了 Server,然后我們向這里插入數據,我們用一個循環去訪問這個隊列,最后的輸出便是我們想要的結果。

接下來我們安裝 workling:
清單 6. 安裝 workling

 script/plugin install git://github.com/purzelrakete/workling.git

Workling 支持多種方式來進行后臺任務操作,其中就包括上面已經安裝的 Starling,安裝好 Starling 后,我們需要在 Rails 應用程序中的 environment.rb 加上以下代碼來配置 Workling 使用 Starling:
清單 7. 使用 workling

 Workling::Remote.dispatcher = Workling::Remote::Runners::StarlingRunner.new

Workling 的配置文件在 workling.yml, 和其它 Rails 的配置文件類似,workling.yml 也可以針對不同產品模式進行不同的模式,這里僅列出 production 的配置。
清單 8. Workling 配置

 production:    listens_on:localhost:15151, localhost:15152, localhost:15153    sleep_time: 2    reset_time: 30    memcache_options:     namespace: myapp

listens_on 參數即為 workling_client 去訪問的 Starling 啟動的地址和端口,這里可以允許多個 Starling 地址,這就意味著你啟動多個 Starling 服務器,而用一個 workling_client 去調用。sleep_time 即為 workling_client 去隊列中取數據的等待時間,reset_time 則定義了如果出現 memcache 錯誤時,workling_client 等待去重建和服務器連接的時間。 在 memcache_options 的 namespace 參數則定義了所使用的命名空間,這在同一臺服務器如果為不同的 Rails 應用啟動同一個 Starling 服務器時是非常有用的。

用 script/workling_client start 腳本便可以啟動 workling_client 進程,有時候我們覺得一個 workling_client 不夠用,我們可以修改 script/workling_client start 來支持多個 workling_client 實例,這樣每運行 script/workling_client start 一次都會新啟動一個 workling_client 實例。
清單 9. 多 client 的 Workling 配置

 options = {  :app_name  => "workling",  :ARGV    => ARGV,  :dir_mode  => :normal,  :dir    => File.join(File.dirname(__FILE__), '..', 'log'),  :log_output => true,  :multiple  => true,  :backtrace => true,  :monitor  => true  }

使用 Memcached 和 cache-money 來緩存數據

Rails 自身提供四種緩存方式,即 Page Cache, Action Cache,Fragment Cache 和 ActiveRecord Cache 這三種緩存。Page Cache 是最高效的緩存機制,他把整個頁面以靜態頁面 HTML 的形式進行緩存,這對于不會經常發生變化的頁面是非常有效的。Action Cache 是對某個 action 進行緩存,與 Page Cache 的區別在于:HTTP 請求會經過 Rails 應用服務器,直到所有的 before filters 都被處理,這種緩存就能處理 Page Cache 無法處理的如需要登錄驗證的頁面,可以所驗證的步驟加入 before filter 中,Fragment Cache 則為了緩存頁面中的某一部分,同一個頁面中的不同部分還可以采用不同的過期策略。對于 Rails 本身的緩存機制,我們可以寫 sweeper 進行過期和清除的處理。ActiveRecord Cache 則是較新版本 Rails 中新推出的對 ActiveRecord 的緩存機制,使用 SQL 查詢緩存,對于同一 action 里面同一 SQL 語句的數據庫操作會使用緩存。

Rails 的緩存機制能非常有效的提升網站性能,Rails 默認是將緩存存在于文件系統中,這并不是適合生產環境下的存儲方式,文件 IO 的效率有限,Rails 還支持在同一進程的內存中保存 Cache,但如果有多個 Rails application,它們之間不能共享緩存。我們這里推薦的是以 MemCached 的方式進行存儲,這也是目前是流行的緩存存儲方式。

Memcached 是由 Danga Interactive 開發,用于提升 LiveJournal.com 訪問速度的。LiveJournal.com 每秒有幾千次動態頁面訪問量,用戶 700 萬。Memcached 是一個具有極高性能的分布式內存對象緩存系統 , 基于一個存儲鍵 / 值對的哈希表。其守護進程(daemon)是用 C 寫的 , Memcached 將數據庫負載大幅度降低,更好的分配資源,更快速訪問。可以用各種其它語言去實現客戶端。上文的介紹中已經安裝了 Rails 的 Memcached 客戶端,因為我們只需要在 Rails 應用程序中做如下配置:
清單 10. Memcached 配置

 config.cache_store = :mem_cache_store, 'localhost:11211'

便可以進行使用 MemCached 進行緩存數據。除了 Rails 本身的緩存機制,我們還直接用 Rails.cache 操作 Memcached 進行數據緩存,如,我們讀取所有 blog 的數量,可以如下使用緩存:
清單 11. 使用 Rails.cache

 blogs_count = Rails.cache.fetch("blogs_count") do   Blog.count  end

Rails 自身的 ActiveRecord 作用有限,只適用同一個 action 中的 SQL 查詢語句進行緩存,我們需要一個更強大的 ActiveRecord 緩存,而 cache-money 更是為了解決如此問題而推出的。當 twitter 網站變得越來越穩定,逐漸擺脫被人拿來作為"Rails 無法擴展的"典型例子的陰影時,人們便期待 twitter 開發團隊能向 Rails 社區有更多的貢獻,cache-money 便是在 Starling 之后 twitter 團隊貢獻出來的另一個插件。cache-money 和 Hibernate 的二級緩存類似,是一個讀寫式(write-through)緩存。在 ActiveRecord 對象更新的時候不是將緩存中的數據清除,而是直接將更新的內容寫入到緩存中去。

cache-money 有許多很棒的特性,如:緩存自動清除機制 ( 利用 after_save/after_destroy) ;支持事務,由于 Rails 的 Active Record 沒有提供 after_commit 機制,目前常見的緩存插件在高并發下會出現緩存更新競爭沖突,而這個特性對于解決這個問題會很有幫助,可以通過 gem 來安裝 cache-money:
清單 12. 安裝 cache-money

 gem sources -a http://gems.github.com  sudo gem install nkallen-cache-money  require 'cache_money'

清單 13. 配置 config/memcached.yml

 production:  ttl: 604800  namespace: ...  sessions: false  debug: false  servers: localhost:11211  development:   ....

清單 14. 使用 config/initializers/cache_money.rb 來初始化

 config = YAML.load(IO.read(File.join(Rails_ROOT, "config", "Memcached.yml")))[Rails_ENV]  $memcache = MemCache.new(config)  $memcache.servers = config['servers']  $local = Cash::Local.new($memcache)  $lock = Cash::Lock.new($memcache)  $cache = Cash::Transactional.new($local, $lock)  class ActiveRecord::Base  is_cached :repository => $cache  end

使用 cache-money 非常方便,不需要額外的操作,只需要在你的 Model 里面進行簡單的配置,如:
清單 15. 配置 Model 來使用 cache_money

 class User < ActiveRecord::Base  index :name  end  class Post < ActiveRecord::Base  index [:title, :author]  end  class Article < ActiveRecord::Base  version 7  index ...  end

然后便可以跟以前一樣使用 Rails ActiveRecord 各種方法以及事務操作。如果你改變了數據庫的表結構,你可以改變 Model 的版本號來使以前的緩存失效,而不需要重啟 Memcached 服務器。

使用 Sphinx+LibMMSeg+Ultrasphinx 進行全文搜索

很多應用會有全文搜索的需求,當然你可以直接集成 google 或者其它搜索引擎提供的搜索服務,但如果你要更好的控制你的搜索結果,或者對你的搜索結果進行再次利用,你恐怕必須得自己實現全文搜索了。在進行中文全文搜索時,一般要考慮兩個方面的問題,即所使用搜索工具的性能問題,以及中文分詞的準備度。在 Java 的世界里,Lucene 是做全文搜索絕對的權威和首選,雖然它本身沒有對中文分詞很好的支持,但有很多第三方插件可以利用來提高中文分詞的準備率和性能。Ferret 一度是最流行的 Rails 全文搜索插件,但本文推薦是效率更高的 Sphinx。Sphinx 是俄羅斯人 Andrew Aksyonoff 開發的,這個詞的意思“獅身人面”,它能在一兩分鐘的時間內完成數百萬條記錄的索引,并在毫秒級的時間類返回搜索結果。 Sphinx 和數據庫集成良好,可以通過配置文件,直接用來對數據庫的數據進行索引,另外,Sphinx 開發了一個 SphinxSE 數據庫引擎,可以在編譯 Mysql 的時候直接編譯到 Mysql 里面去來實現數據庫級別的高效能索引。在 Rails 中使用 Sphinx 可以通過 Ultrasphinx 插件,Rails 開發人員可以使用它來很方便地調用 Sphinx 的功能。

可以從這里 http://www.sphinxsearch.com/downloads.html 下載 Sphinx

在安裝好 Sphinx 后可以直接從 Rubyforge 上安裝 Ultrasphinx:
清單 16. 安裝 ultrasphinx

 Ruby script/plugin install svn://Rubyforge.org/var/svn/fauna/ultrasphinx/trunk

LibMMSeg 就是一個中文分詞程序,當前最新版本是 0.7.3,采用 C++ 開發,分詞算法采用的是“復雜最大匹配 (Complex maximum matching)”,同時支持 Linux 平臺和 Windows 平臺,切分速度大約在 300K/s(PM-1.2G),LibMMSeg 從 0.7.2 版本開始,作者提供了 Ruby 調用的接口,所以我們可以直接在 Ruby 中用 LibMMSeg 進行分詞,相當方便。LibMMSeg 可以通過 http://www.coreseek.cn/opensource/mmseg/ 來下載安裝。

用戶可以通過修改詞典文件增加自己的自定義詞,以提高分詞法在某一具體領域的切分精度,系統默認的詞典文件在 data/unigram.txt中。 然后通過 mmseg -u unigram.txt這個命令來產生一個名為 unigram.txt.uni的文件,將該文件改名為 uni.lib,完成詞典的構造。需要注意的是,unigram.txt必須為 UTF-8 編碼。

LibMMSeg 的開發者為了更好的讓 Sphinx 使用 LibMMSeg 進行中文分詞,為 Sphinx 開發了相關的補丁,從這里 http://www.coreseek.cn/opensource/Sphinx/ 下載兩個補丁文件:

http://www.coreseek.com/uploads/sources/sphinx-0.98rc2.zhcn-support.patch

http://www.coreseek.com/uploads/sources/fix-crash-in-excerpts.patch

然后打上補丁:
清單 17. 安裝 Sphinx 補丁

 cd sphinx-0.9.8-rc2  patch -p1 < ../sphinx-0.98rc2.zhcn-support.patch  patch -p1 < ../fix-crash-in-excerpts.patch

安裝完這幾個插件和補丁之后,我們便可以進行配置來讓 Rails 應用程序來支持全文搜索了,

首先我們將 ultrasphinx 插件目錄下的 vendor/plugins/ultrasphinx/examples/default.base復制到:config/ultrasphinx/default.base,打開這個文件,將其中的:

charset_type = utf-8改為:charset_type = zh_cn.utf-8來支持中文字符的全文檢索, 并且在 charset_type 設置的下面加入一行:

charset_dictpath = /home/test/Search/lib,這個就是上文講到的 uni.lib 字典所在的路徑,然后刪除所有 charset_table 相關的設置。

在 Rails 應用程序中的 Model 代碼,加入全文檢索支持:

如有一個 Model 為 Article,其中有兩個屬性叫做 title,body,我希望對這兩個屬性做全文檢索,便可以在 article.rb 中加入一行:
清單 18. 使用 ultrasphinx

 is_indexed :fields => ['created_at','title', 'body']

進行完這個配置后,我們可以使用 rake ultrasphinx:configure 這個命令來生成Sphinx 的配置文件,這條命令在 config/ultrasphinx 下創建了一個 development.conf,這個文件就是 Sphinx 的配置文件。并用rake ultrasphinx:index 這個命令來創建索引。rake ultrasphinx:daemon:start 和 rake ultrasphinx:daemon:stop 則對應著Sphinx 的searchd服務的啟動和停止。searchd 會在 3313 端口啟動一個 searchd,搜索請求將會全部發送到這個端口來執行。我們在控制臺中進行簡單的測試:
清單 19. 測試全文索引

 search = Ultrasphinx::Search.new(:class_names => 'Article')  search.run  Search.results 

一切運行正常后,我們便可以在 action 的代碼中進行全文搜索了。

使用 Capistrano 進行快速部署

在進行 Rails 部署的時候你可以直接從 svn 或者 git 下面更新代碼,運行 db:migrate 來進行數據庫的更新,然后進行這樣那樣的操作后,再啟動服務器,便可進行部署,即便你只有一臺機器,你也會覺得太麻煩,如果你需要多臺機器來運行,那你可能就會覺得每次手工部署都是一場惡夢,你可以使用 shell 腳本來簡化部署的程序。在用 Rails 開發應用時,你可以使用 Capistrano 插件來進行更簡單的部署工作。簡單來說,Capistrano 是一個通過 SSH 并行的在多臺機器上執行相同命令的工具,使用用來安裝一整批機器。 它通過一個個已有的和用戶自定制的任務讓部署過程簡單化。
清單 20. 安裝 Capistrano

 gem sources -a http://gems.github.com/  gem install Capistrano

然后在 config/deploy.rb 中配置要部署的服務器的地址,各種服務器的角色以及每個服務器統一的用戶名和密碼,如下面的樣例配置:
清單 21. 配置 Capistrano

 set :application, "test_app" # 應用的名稱 set :scm_username, "test"  # 資源庫的用戶名 set :scm_password, 'test'  # 資源庫的密碼 set :repository, Proc.new {"--username #{scm_username}  --password #{scm_password} svn://localhost/test_app/trunk"}   # 資源庫 set :user, "test"  # 服務器 SSH 用戶名 set :password, 'test' # 服務器 SSH 密碼 set :deploy_to,    "/var/www/#{application} "  # 在服務器上的部署路徑,默認的部署路徑是 /u/apps/#{application}  role :Web, 'Web.test_app.com' # 前端 Web 服務器 role :app, 'app1.test_app.com', 'app2.test_app.com', 'app3.test_app.com' #Rails 應用服務器 role :db, 'app1.test_app.com', :primary => true  # 運行 migrate 腳本的機器,通常為其中一臺應用服務器。

在使用 Capistrano 進行部署的時候,通常是這樣使用 cap sometask來運行任務。你可以先用 cap -h查看所有的選項,并用 cap -T查看現有的所有任務。如 cap migrate則在 role 為 db 的機器上執行 rake db:migrate命令。使用 Capistrano 的更多資料可以參考 http://wiki.capify.org 這個網站。另外,Capistrano 還可以使用在非 Rails 環境下進行自動部署,在配置好 ruby 環境和 Capistrano 插件后,再安裝下面的插件即可:
清單 22. 非 Rails 環境使用 Capistrano

 gem sources -a http://gems.github.com/  gem install leehambley-railsless-deploy

結束語

本文著重使用 Ruby On Rails 來開發和部署 Web 應用時一些有用的具體實踐,沒有具體去介紹一些通常應用程序都需要面對的普遍問題,如數據庫的優化和分布式部署,這是一個大并發的 Web 應用都需要面對和解決的問題,比如可以采用 master-slave 的方式去部署分布式的數據庫,或者采用分庫或者分表的方式對數據庫進行拆分。另外,在運行 Rails 服務器或者其它后臺應用程序時,通過還需要另外的進程去進行監控,如用 God 去監控 Rails 進程也是一個 Rails 應用通常都會采用的策略。另外,很多時候,可以采用更敏捷更輕量級的 Rack 去代替 Rails 來進行更高效的開發的提供服務。并且,Engineyard ,Joyent 以及 Heroku 等這類 Rails 網絡提供商的涌現也在相當程度上堅定了用 Rails 開發和部署大規模大并發 Web 應用的信心。雖然 Ruby On Rails 自身的缺陷不可避免, 但是開發可伸縮的高性能的應用程序并不是不可能的。本文希望能夠幫助 Rails 開發人員快速掌握一些具體實踐,能夠編寫出并部署性能高伸縮性強的 Web 應用程序。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
9久久9毛片又大又硬又粗| 久久久久免费精品国产| 91精品欧美久久久久久动漫| 日韩一级完整毛片| 在线a欧美视频| 亚洲电影网站| 日韩av一区二区三区在线观看| 91影院在线播放| 久草热在线观看| 男人天堂av网| 26uuu色噜噜精品一区二区| 欧美高清在线一区| 精品久久久久久久大神国产| 制服丝袜中文字幕一区| 日韩精品在线电影| 日本精品一区二区三区在线播放视频 | 亚洲在线免费观看视频| 亚洲av无码精品一区二区 | 91久色porny| 欧美日韩成人在线| www.欧美精品| 欧美大陆一区二区| 中文字幕av不卡在线| 青娱乐国产在线| 亚洲男人的天堂在线视频| 热久久免费视频| 亚洲一区在线观看免费观看电影高清 | 久久国产精品免费看| 老**午夜毛片一区二区三区 | 一区二区三区精品99久久| 欧美在线免费看| 99亚洲国产精品| 日本少妇一区二区三区| 天堂在线中文视频| 日韩主播视频在线| 不卡大黄网站免费看| 欧美一三区三区四区免费在线看 | 日韩成人av一区二区| 波多野结衣加勒比| 鲁大师私人影院在线观看| 国产喷水吹潮视频www| 精品一区二区三区影院在线午夜 | 欧美韩国日本不卡| 亚洲午夜免费福利视频| 色综合五月天导航| 亚洲国产精品毛片| 人妻视频一区二区| 日本少妇一区二区| 国产午夜亚洲精品午夜鲁丝片| 国产亚洲精品久久久优势| 色综合久久久久久中文网| 国产精品青草久久久久福利99| 国产丝袜不卡| 黄色国产在线观看| 国产一区二区免费在线| 欧美三级电影在线看| 97超碰资源| 一本一本久久a久久| 91丨九色丨国产丨porny| 色婷婷综合成人| 国产精品网站免费| www.成人免费视频| 欧美撒尿777hd撒尿| 国产日韩在线一区二区三区| a资源在线观看| 国产三级三级三级精品8ⅰ区| 久久影视电视剧免费网站清宫辞电视| 青青草国产精品视频| 亚洲图片中文字幕| 欧美一区二区三区白人| 国产系列第一页| 在线观看视频二区| 欧美久久高跟鞋激| 可以看毛片的网址| 久久黄色网页| 这里只有精品在线播放| 日韩黄色片视频| 五月婷婷伊人网| http;//www.99re视频| 中文字幕一精品亚洲无线一区| 姬川优奈aav一区二区| 色偷偷888欧美精品久久久| 激情小说网站亚洲综合网| 岛国精品一区二区三区| 性生活三级视频| 在线观看不卡视频| 日本不卡二区| 亚洲大尺度网站| 欧美成人精品福利| 国产91对白刺激露脸在线观看| 欧美一级在线免费观看| 一区二区三区蜜桃| 国产午夜精品美女视频明星a级| 97久久国产亚洲精品超碰热| 亚洲精品综合久久| 日韩欧美123| 粉色视频免费看| 日韩电影一二三区| 91地址最新发布| 激情五月色婷婷| 亚洲欧洲午夜一线一品| 亚洲成人激情小说| 亚洲资源在线观看| 日本一区精品| 久久av中文字幕片| 亚洲自拍另类欧美丝袜| 欧美做爰爽爽爽爽爽爽| 色视频一区二区| 天堂av8在线| 国产成人精品免费| 国产91精品一区二区绿帽| 一区二区三区免费在线视频| 久久久精品免费视频| 久久久久久久久毛片| 欧美精品一区二区三区视频| 亚洲精品一二三四| 亚洲国产aⅴ成人精品无吗| 午夜久久久久久久久久久| 国产精品一区一区| 六月婷婷久久| 欧洲精品久久一区二区| 国产成人精品999| 天堂中文在线看| 亚洲xxxx视频| 国产精品中文字幕日韩精品| 欧美理论一区二区| av不卡免费电影| 岛国大片在线播放| 亚洲天堂a在线| 蜜桃免费在线视频| 欧美色涩在线第一页| 国产人妻大战黑人20p| 精品国产麻豆免费人成网站| 成熟人妻av无码专区| 精品亚洲男同gayvideo网站 | 国产精品嫩草久久久久| 一区二区日本伦理| 中文字幕中文字幕中文字幕亚洲无线 | 91丝袜美腿高跟国产极品老师| 欧美 日韩 亚洲 一区| 亚洲天堂成人在线观看| 亚洲女人天堂网| 国产67194| 欧美在线精品免播放器视频| 日本欧美一区二区在线观看| 日本一区网站| 色婷婷国产精品| 精品99在线观看| 国产精品三级美女白浆呻吟| 丁香网亚洲国际| 无人在线观看的免费高清视频| 精品国产免费久久 | 欧美一区二区三区图| 国产九九视频一区二区三区| 日本欧美黄色片| 亚洲精品大尺度| 日本免费一区视频| 草草草视频在线观看| 日韩欧美成人午夜| 亚洲爆乳无码一区二区三区| 中文网丁香综合网| 欧美日韩国产美| 综合久久中文字幕| 黄色网zhan| 日韩精品在线视频美女| 黄色片一区二区| 91chinesevideo永久地址| 成人免费电影视频| 成人免费看aa片| 国产精品黄视频| 中文成人综合网| 日本在线观看中文字幕| 免费成人深夜夜行视频| 欧美色手机在线观看| 国产乱码精品一区二区| 人九九综合九九宗合| 91免费版在线| 国产传媒国产传媒| 亚洲一区二区三区四区视频| 久久九九全国免费| 亚洲精品无码久久久久久久| 欧美日韩成人在线播放| 国产91高潮流白浆在线麻豆| 国产调教打屁股xxxx网站| 日本成人免费在线| 午夜精品在线看| 一级全黄少妇性色生活片| 国产亚洲精品自在久久| 欧美色图一区二区三区| 日韩在线一区二区三区| 亚洲黄色小说在线观看| 国产精品福利在线观看| 亚洲欧洲av在线| 97超碰人人草| 国产成人av影视| 一区二区三区91| 五月天婷婷色综合| 欧美黄色直播| 久久精品成人动漫| 国产婷婷一区二区| 欧美特黄aaaaaa| 免费在线观看日韩视频| 国产精品久久久久久久久久三级| 午夜a成v人精品| 秋霞午夜av一区二区三区| 日本裸体美女视频| 黄色成人在线看| 成人国产精品av| 亚洲成人av在线播放| 国产精品乱子久久久久| 亚洲国产精品久久久久久久| 亚洲av无码一区二区三区人| 涩涩日韩在线| 97色在线视频观看| 欧美一级二级三级蜜桃| 国产精品久久久久aaaa| www.av日韩| 99精品中文字幕| 国产精品一区二区羞羞答答| 97视频中文字幕| 久久在线免费观看视频| 欧美视频免费在线观看| 国产很黄免费观看久久| 国产视频精品免费| 亚洲三级在线观看视频| 亚洲第一综合网站| 91精品在线一区| 琪琪亚洲精品午夜在线| 亚洲男人天堂手机在线| 91成人国产精品| 久久综合五月天婷婷伊人| 777777国产7777777| 五月天激情视频在线观看| 久久偷看各类wc女厕嘘嘘偷窃| 欧美极度另类性三渗透| 日韩av在线免费看| 日本精品视频一区二区| 欧美激情一区在线| 国产一区二区电影| 日本黄色三级视频| 国产精品久久久久久人| 久久久久久九九九九九| 免费看欧美一级片| 亚洲高清不卡一区| 国产精品二区三区| 亚洲人成网站999久久久综合| 欧美唯美清纯偷拍| 亚洲国产aⅴ成人精品无吗| 99综合电影在线视频| 国产麻豆视频一区| 国产精品888| 看片的网站亚洲| 久久精品卡一| 欧美日韩 一区二区三区| 九九热精品在线观看| 男人和女人啪啪网站| 色一区av在线| 精品久久久久久久久久久久久久久久久 | 一区二区三区国产在线观看| 欧美v日韩v国产v| 欧美老人xxxx18| 欧美性猛交一区二区三区精品| 91成人免费网站| 欧美日韩国产大片| 3d动漫精品啪啪1区2区免费| 亚洲摸摸操操av| 色婷婷综合激情| 亚洲午夜免费福利视频| 亚洲男帅同性gay1069| 国产女主播在线一区二区| 国产一区二区在线电影| 成人午夜电影网站| 懂色av中文字幕一区二区三区 | 国产精品高潮呻吟久久| 欧美韩日一区二区三区四区| 北条麻妃国产九九精品视频| 极品销魂美女一区二区三区| 国产自产v一区二区三区c| 国产精品99久久久久久有的能看| 精久久久久久久久久久| 免费成人av资源网| 麻豆一区二区三区| 91麻豆国产精品久久| 久久久91精品国产一区二区三区| 国产精品国产精品国产专区不蜜| xnxx国产精品| 狠狠躁夜夜躁人人躁婷婷91| 制服丝袜亚洲色图| 色爱av美腿丝袜综合粉嫩av| 国产日本欧美在线观看| 日韩欧美一区二区视频在线播放 | www.99热这里只有精品| 182午夜在线观看| 成年人网站免费在线观看| 疯狂揉花蒂控制高潮h| 成人免费视频入口| 国产精品7777| 国产精品无码一区| 美日韩一级片在线观看| 91免费看`日韩一区二区| 欧美日韩精品中文字幕| 欧美色男人天堂| 69av在线视频| 国产精品嫩草在线观看| 品久久久久久久久久96高清| 免费日韩视频在线观看| 污污污www精品国产网站| 国产真实乱人偷精品视频| 91极品身材尤物theporn| 香蕉视频免费看| www.日本不卡| 色综合久久中文综合久久牛| 中文字幕国产精品| 国产成人成网站在线播放青青| 国产精品宾馆在线精品酒店| www.久久久精品| 2017亚洲天堂| 亚洲av无码一区二区三区dv| 日本一区二区三级电影在线观看| 日韩成人中文字幕| 国产精品一区二区久久| 国产精品入口芒果| 青青草视频成人| 污视频网站在线播放| 国产午夜一区二区三区| 精品免费视频.| 不卡视频一区| 自拍偷拍一区二区三区四区| 欧美a视频在线观看| 亚洲欧洲www| 久久成年人视频| 一区二区三区国| 天天看片中文字幕| 不卡的av电影在线观看| 日韩一区二区三区观看| 91久久精品国产91久久性色tv| 国产一级免费大片| 99精品视频在线播放免费| 有码一区二区三区| 国产精品一区二区久久精品| 一级黄色片在线免费观看| www.中文字幕| 欧美日韩一本到| 精品免费视频123区| 亚洲视频天天射| 国产综合色在线| 在线日韩第一页| 天天夜碰日日摸日日澡性色av| 99热这里只有精品在线| 亚洲超丰满肉感bbw| 91久久国产精品91久久性色| 性高潮久久久久久久| 99久久综合精品| 18久久久久久| 亚洲av成人片色在线观看高潮| 国产黄色片网站| 一本久久a久久精品亚洲| 精品一区二区国产| 9i精品福利一区二区三区| 欧美午夜精品久久久久久久| 国产精品久久婷婷六月丁香| 日本 欧美 国产| 五月天精品一区二区三区| 免费观看成人高| 97超碰中文字幕| 亚洲精品日韩在线| 亚洲日本精品视频| 国产精品伊人久久| 国产精品青草久久| 久久中文字幕一区| 波多野结衣家庭教师在线| 国产大陆精品国产| 国产精品对白刺激久久久| 亚洲免费在线视频观看| 成人avav在线| 最近2019中文字幕一页二页| 成年人免费视频播放| 精品国产91乱码一区二区三区| 国产av自拍一区| 91久久精品一区二区三区| 精品一卡二卡三卡四卡日本乱码| 男女性高潮免费网站| 欧美激情一区二区三区蜜桃视频| 久久青草精品视频免费观看| 精品无码国模私拍视频| 欧美一区免费看| 欧美伊人久久久久久午夜久久久久| av一区二区三区免费| 天天干天天舔天天操| 成人ar影院免费观看视频| 久久精品国产成人精品| 日韩电影免费观看在| 国产ts在线播放| 久久久久国产一区二区三区四区 | 中文字幕乱妇无码av在线| 视频一区中文字幕| 91精品国产成人www| 女人天堂av手机在线| 免费日本视频一区| 日韩精品小视频| 日韩人妻一区二区三区| 亚洲视频国产视频| 日韩高清在线不卡| 久久美女福利视频| 精品一区电影国产| 91精品国产高清一区二区三蜜臀| 久久精品免费电影| 中文字幕视频免费观看| 日韩美女视频中文字幕| 日韩成人精品在线观看|