質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.12%
Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

解決済

RedisをJSON形式で保存するのはアリ?

退会済みユーザー

退会済みユーザー

総合スコア0

Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。

2回答

0リアクション

0クリップ

9001閲覧

投稿2017/02/21 08:07

本番サービスで初めてRedisを使った運用をする予定です。

現在実装しようとしているのは、ユーザーがどのルームに入っているかの情報をRedisで保存する機能です。
ユーザーIDをキーに、ルームIDをバリューに入れるだけでも良いのかと当初は考えたのですが、複数デバイスからの利用を考えると次のような実装にしようと考えています。

アイデア 1

各ユーザーごとに独立したハッシュ型の値を生成し、キーにルームID、値に接続数を保存。

接続数というのは、例えばスマホとPCで同じルームにアクセスしていた場合、どちらか一方が抜けてしまってもオフライン判定にならないように、端末ごとにカウントするものを想定しています。

(サンプル)

ルームID接続数
11
22
41

【懸念点】

・ユーザーごとにキーを生成すると、キーが多くなりすぎて管理が煩雑になりそう?

アイデア 2

接続数を管理するのは一つのキーで、ユーザーIDごとにJSONで管理する

アイデア1のハッシュ型をJSONの形式で埋め込んでしまうことで、一つのキーだけで管理できるようにします。

(サンプル)

ユーザーID
1"{1: 1, 2:2, 4:1}"
2"{5: 1, 9: 3, 12: 1}"
3"{15: 1, 91: 3, 122: 1}"

【懸念点】

・そもそもJSON形式の運用はイレギュラーなのでは?という不安
・JSONにすることでデコード時などにオーバーヘッドが生じる

今回思いついた案としては上の二つがあり、どちらが運用上適切かどうか教えていただけないでしょうか。
またこの2つ以外にもっと良い方法がありましたら、ぜひ教えて頂けると幸いです。

よろしくお願いします。

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.12%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Redis

Redisは、オープンソースのkey-valueデータストアで、NoSQLに分類されます。すべてのデータをメモリ上に保存するため、処理が極めて高速です。