最初に言ってしまいますと、Qiita の以下の記事を(ほぼ丸々そのまま)参考にさせていただいて実装を行っています。
RailsのセッションストアとしてRedisを使う(Mac/EC2:AmazonLinux) | Qiita
若干自分好みに環境設定を変えているのと、本番環境が AWS と heroku で違うだけです。
元ネタの記事をご覧になっていただいた方が話が早いかもしれません。
この頃評判のいい Redis をセッションの保存先として使用するよう設定してみました。
Rails のセッションの保存先はデフォルトでは Cookie ですが、下のような話もあるので検討の結果 Redis にしてみた感じです。
Rails SessionにCookieStore使った時の問題点 | OAuth.jp
一応調査するにあたっていろいろ調べたのですが、こういうサイトの性能比較を見ると結構すごいな、と思わされます。
ももクロスライダーで測る Redis vs MongoDB on Heroku 第二弾
NoSQLデータベースガイドを読みました。著者: @sasata299
Mac に Redisをインストール
全く同じ手順でうまく行きますので、元ネタ様 を参照してください。
Rails に Redis を導入
若干変えています。
gem 'redis'
gem 'redis-rails'
# Rails.application.config.session_store :cookie_store, key: 'XXXXXX'
Rails.application.config.session_store :redis_store, servers: Rails.application.config.session_store_servers, expire_in: BestTeacher::Application.config.session_expires_in
Rails.application.configure do
:
# for session store.
config.session_store_servers = 'redis://localhost:6379/0'
:
end
Rails.application.configure do
:
# for session store.
config.session_store_servers = ENV["REDISCLOUD_URL"]
:
end
staging.rb も production.rb と同じ修正を行います。
環境変数は Redis Cloud を前提としていますので、他のアドオンにする場合は適宜読み替えてください。
Redis の動作確認が正常に行っていれば、コードの修正はこれだけ。
サーバを再起動すれば正常にセッションの保存がうまく行くようになるはずです。
※ 当然セッションの保存先が変わるので、ログイン済みのユーザは再ログインが必要になります。
なお、もしセッションとは異なるデータも Redis に同居状態で格納したいという場合には、以下のように接頭詞のようなものを着けることも出来ます。
Rails.application.configure do
:
# for session store.
config.session_store_servers = 'redis://localhost:6379/0/session'
:
end
でもまあ、基本的には database を別に(末尾の0とかの数字を変えるだけ)すべきだと思います。
Redis に保存されたデータを確認
元ネタ様 を参照してください。
なお、もし接頭詞を着けた場合はこんな感じでキーを検索できると思います。
127.0.0.1:6379> keys session*
1) "session:f1412e2bbe5df2091ebdf2e3025e2335"
どの Redis のアドオンを使う?
現在、heroku には4つの Redis のアドオンがあります。
早晩5つめが増えるようです。
- Redis Cloud | Add-ons | Heroku
- Redis To Go | Add-ons | Heroku
- RedisGreen | Add-ons | Heroku
- openredis | Add-ons | Heroku
正直どれがいいの?というのはよくわからないのですが、比較サイトがありました。
HEROKU REDIS PROVIDER COMPARISON: OPENREDIS, REDIS TO GO, REDISGREEN, REDIS CLOUD
表形式で比較選択しやすいように並べて表示してあるので、大変助かります。
とりあえず安さに惹かれて Redis Cloud にしてみました。
技術情報 Redis Cloud | Heroku Dev Center を見ると他の既存の Redis からデータ移行を行いやすいように整備されていて、なかなか野心的で良いと思います。
実際に触ってみないと確かなことは言えませんが、バックアップデータにアクセスも出来るようになっているあたりも素敵です。
容赦なく他のアドオンに移行することも出来るってことですよね。
プランにより複数の database をさくっと作ることが出来るのは良いのですが、 database ごとに容量制限、 quota みたいなことは出来ないんでしょうか。
Redis 本体にもそういう機能があるようには見えなかったんですが、例えばセッションとキャッシュで database を分けつつ利用したいけど、セッションの方には多めに容量確保したいとかできないかなーと思ったりしました。
なお、この記事を書いている現時点ではまだステージング環境でも評価を行っていません。
動作確認や本番リリース後、記事に間違いなどあった場合は修正しますが、未確認情報を含む点があることをあらかじめご了承ください。