在Ruby on Rails上使用Redis Store的方法

来源:爱站网时间:2019-05-12编辑:网友分享
Redis Store 是一个Ruby应用程序的工具包,自然支持碎片、主从复制、编组、超时和名称空间,其实在RubyonRails中使用非常简单,下面就让爱站技术频道小编带你来学习在Ruby on Rails上使用Redis Store的方法。

Redis Store 是一个Ruby应用程序的工具包,自然支持碎片、主从复制、编组、超时和名称空间,其实在RubyonRails中使用非常简单,下面就让爱站技术频道小编带你来学习在Ruby on Rails上使用Redis Store的方法。
 如何使用:
对于在Rails上使用Redis Store,首先我们需要在Gemfile文件中添加入口
 

ruby;">
gem 'redis-rails'
gem 'redis-rack-cache' # optional

然后我们就会有如下选择:

## Cache Store
# config/environments/production.rb
config.cache_store = :redis_store
 
## Session Store
# config/initializers/session_store.rb
MyApplication::Application.config.session_store :redis_store,
servers: ['redis://:secret@192.168.6.23:6379/0', 'redis://:secret@192.168.6.99:6379/1']
 
## HTTP Cache
# config.ru
require 'rack'
require 'rack/cache'
require 'redis-rack-cache'
 
use Rack::Cache,
metastore: 'redis://localhost:6379/0/metastore',
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。

就个人而言,爱站技术频道小编认为它基本上是一个插件,必须在服务器环境中使用,是一种很好的工具。

上一篇:讲解Ruby中Block和迭代器的使用方法

下一篇:Ruby之模块基础知识

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载