ruby on rails怎么使用redis

Python0511

ruby on rails怎么使用redis,第1张

对于在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://:[email protected]:6379/0', 'redis://:[email protected]: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一样,为了使用它,你必须花费大量的时间与安装与配置才能在性能,以及内存使用上找到一个绝佳的平衡点。

您可能感兴趣的文章:

安装redis集群需要版本号在3.0以上redis-cluster安装前需要安装ruby环境搭建集群需要使用到官方提供的ruby脚本。需要安装ruby的环境。yum-yinstallrubyyum-yinstallrubygemsredis集群管理工具redis-trib.rb[root@bogon~]#cdredis-3.0.0[[email protected]]#cdsrc[root@bogonsrc]#ll*.rb-rwxrwxr-x.1rootroot48141Apr107:01redis-trib.rb脚本需要的ruby包:redis-3.0.0.gem安装geminstallredis-3.0.0.gem[root@bogon~]#geminstallredis-3.0.0.gemSuccessfullyinstalledredis-3.0.01geminstalledInstallingridocumentationforredis-3.0.0InstallingRDocdocumentationforredis-3.0.0集群的搭建需求,创建6台redis服务器,虚拟机模拟端口号为7001-7006第二步:修改redis的配置文件1、修改端口号第三步:把创建集群的ruby脚本复制到redis-cluster目录下。第四步:启动6个redis实例第五步:创建集群。

因为在redis/src中有一个文件叫做redis-trib.rb,这个文件就是作者用Ruby写的,用来搭建redis集群(redis3.0版本时才开始支持集群),redis-trib.rb的后缀就是Ruby的简写,所以想要搭建redis集群需要有一个能执行.rb这种文件的运行环境,这个环境就是Ruby。