当前位置: 移动技术网 > IT编程>脚本编程>Ruby > 在Ruby on Rails上使用Redis Store的方法

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

2017年12月08日  | 移动技术网IT编程  | 我要评论

redis store 是一个专为ruby应用程序服务的工具包,原生就支持分片,主从复制,编组以及超时和命名空间。此外,在ruby on rails上使用它也是非常的简单。
 如何使用:
对于在rails上使用redis store,首先我们需要在gemfile文件中添加入口
 

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。

总结

我个人认为 redis 基本算是你的服务器环境必须用用的一个插件,它速度快而且可使用范围广泛,比如可以作为数据库,缓存,分片机等等,真算得上是一个不错的工具。然而任何好处都是有代价的:与rails一样,为了使用它,你必须花费大量的时间与安装与配置才能在性能,以及内存使用上找到一个绝佳的平衡点。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网