开发者社区> 问答> 正文

Redis Store的使用

Redis Store 是一个专为Ruby应用程序服务的工具包,原生就支持分片,主从复制,编组以及超时和命名空间。有没有好的案例参考一下?

展开
收起
落地花开啦 2016-02-18 16:00:42 2867 0
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://: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模块也是不需要启动的。

    2019-07-17 18:44:06
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Redis4.0解密 立即下载
Getting Rezdy to Use Redis wit 立即下载
Redis Cluster的基本原理 立即下载