主頁 > 行業資訊 > 國外 >
欄目列表

junwong 介紹 Redis Store

來源:oschina 作者:junwong 發表于:2012-06-25 13:38  點擊:
Redis Store 是一個專為Ruby應用程序服務的工具包,原生就支持分片,主從復制,編組以及超時和命名空間。此外,在Ruby on Rails上使用它也是非常的簡單。 如何使用: 對于在Rails上使用Redis Store,首先我們需要在Gemfile文件中添加入口 1 gem redis-rails
Redis Store 是一個專為Ruby應用程序服務的工具包,原生就支持分片,主從復制,編組以及超時和命名空間。此外,在Ruby on Rails上使用它也是非常的簡單。


 
如何使用:
對于在Rails上使用Redis Store,首先我們需要在Gemfile文件中添加入口
1 gem 'redis-rails'
 
2 gem 'redis-rack-cache' # optional
 
 
然后我們就會有如下選擇:
01 ## Cache Store
 
02 # config/environments/production.rb
 
03 config.cache_store = :redis_store
 
04  
 
05 ## Session Store
 
06 # config/initializers/session_store.rb
 
07 MyApplication::Application.config.session_store :redis_store,
 
08 servers: ['redis://:[email protected]:6379/0', 'redis://:[email protected]:6379/1']
 
09  
 
10 ## HTTP Cache
 
11 # config.ru
 
12 require 'rack'
 
13 require 'rack/cache'
 
14 require 'redis-rack-cache'
 
15  
 
16 use Rack::Cache,
 
17 metastore: 'redis://localhost:6379/0/metastore',
 
18 entitystore: 'redis://localhost:6380/0/entitystore'
 
 
如你所見,使用這個插件相當簡單,但現在我要教你如何去管理這些設置。
第一個案例不言自明,我們來說說用 ActiveSupport 來加載Redis Store。這里請記住,Redis的contraire僅僅只能支持字符串,所以可以利用序列化與反序列化技術來存儲任何對象。
 
這里的第二個案例就稍微復雜一點。首先,我們需要使用一個服務器集群。這里再重復一遍,Redis Store支持分片,也就意味著Http會話在兩臺服務器之間都是互相透明可見的。
 
最后一個案例主要涉及到Ruby的Http緩存代理,這 些緩存的主要作用就是為了加快Http響應,而且也是以名值對的方式來存儲meta數據以及entity實體對象的,這里也提一下,如果我們存儲的都是普 通的字符串文本,那么 mashalling模塊也是不需要啟動的。
 
雖然說了這么多,但就上面幾點也只是 Redis store 所有功能的一小部分而已,其實它還支持Rack,Sinatra以及I18n。
 
總結
我個人認為 Redis 基本算是你的服務器環境必須用用的一個插件,它速度快而且可使用范圍廣泛,比如可以作為數據庫,緩存,分片機等等,真算得上是一個不錯的工具。然而任何好 處都是有代價的:與Rails一樣,為了使用它,你必須花費大量的時間與安裝與配置才能在性能,以及內存使用上找到一個絕佳的平衡點。

    有幫助
    (0)
    0%
    沒幫助
    (0)
    0%
  • 上一篇:火狐求變:推開源移動操作系統
  • 下一篇:沒有了
    黑龙江体彩6十1开奖号