Discourse は Redis を何に使用していますか?

現在、私の Discourse インストールでは、DigitalOcean のマネージド PostgreSQL データベースと、DigitalOcean のマネージド Redis インスタンスを使用しています。マネージド Redis サーバーは必要でしょうか?

Discourse は永続的なデータを Redis に格納するのでしょうか、それともキャッシングやその他の一時的なデータのためだけに使用されるのでしょうか?

現在の設定(明らかにオーバースペックですが、将来的に必要になった場合に拡張が容易になります):

  • DigitalOcean のマネージド PostgreSQL サーバー
  • DigitalOcean のマネージド Redis インスタンス
  • DigitalOcean のロードバランサー
  • Discourse を実行している 2 台の DigitalOcean ドロップレット

私が考えているよりシンプルな構成は以下の通りです:

  • DigitalOcean のマネージド PostgreSQL サーバー
  • Redis と Discourse アプリケーションの両方を実行する単一のサーバー(必要に応じてフェイルオーバー用のバックアップサーバーへ移行するためのフローティング IP を備える)

現在の構成では、外部の Redis サーバーのおかげで、ユーザーに気づかれずに Web サーバーをシームレスに切り替えることができます。よりシンプルな構成の場合、フェイルオーバーサーバーが必要になった際にユーザーがログアウトされてしまう可能性があります。Redis を Discourse と同じサーバー上で実行することの主な欠点はこれでしょうか?

よろしくお願いいたします、
Francis

+1 私も同じ質問があります。Redis と Discourse について、もう少し詳しく説明していただけないでしょうか :kissing_smiling_eyes:

Discourse は、オープンソースの ジョブスケジューラ である Sidekiq を使用しています。Sidekiq は Ruby で書かれています。Sidekiq は一般的に(デフォルトでは)ジョブの実行のみを行い、スケジューリングは行わないとされています(少なくとも参考文献にはそう記載されています。状況は変わったかもしれませんが)。ただし、Sidekiq のエンタープライズ版にはスケジューリング機能が標準搭載されていると理解しています。

Sidekiq は、インメモリデータ構造ストアである Redis を使用しており、これも Ruby で書かれています。Sidekiq は Redis キューからジョブを読み取り、ジョブを処理するために 先入れ先出し (FIFO) モデルを採用しています。ジョブ処理は非同期で行われ、重いタスクを「スケジューリング」してバックグラウンドで実行させることで、Web スレッドが生きたリクエストに応答できるようにします。

Sidekiq は「よく知られたキュー処理ソフトウェア」として説明されており、Discourse では Web アプリケーションのリクエスト内で直接実行されるのではなく、バックグラウンドタスクとして実行されるように設計されたジョブに使用されています。

上記の簡単な概要に基づき、Discourse が実行するジョブのさまざまな種類は、Discourse のリポジトリで確認できます。

Redis は Discourse のアーキテクチャの他の部分でも使用されている可能性がありますが、私の記憶にある限り、Redis の主な用途は Sidekiq(通称「ジョブ担当」)の「コンパニオン」として機能することです。Discourse の HLA(High-Level Architecture)について私よりも詳しい Discourse チームメンバーが、Discourse の HLA 内で Redis がどのように使用されているかについて、さらに詳しい説明を加えてくれるはずです。

お役に立てれば幸いです。

これは少し古い投稿ですが、他の Discourse の Redis 関連の情報を検索している際にこの問題に遭遇したため、この返信を補足しておきます。

Discourse が Sidekiq 以外に Redis を何に使用しているかという質問に対するチームメンバーからの回答は以下の通りです。

@Francisさん、DigitalOceanのサービス全体の請求額の見積もりはいくらでしたか?Google Cloudに同じサービスをインストールする予定なので、興味があります(無料の200ドル)。DiscourseのSaaSサービスの価格は予算オーバーです。

推測ですが、ロードバランサー、Redis、Postgresで月額50ドルに加えて、ドロップレット(複数可)の料金がかかるでしょう。

コストが気になる場合は、2GBのドロップレットをお勧めします。それでも足りない場合は倍増させてください。