目次
単一マシン モード
マスター/スレーブ モード
Sentinel モード
クラスター モード
ホームページ データベース Redis Redis クラスター モードとは何ですか?またその利点は何ですか?

Redis クラスター モードとは何ですか?またその利点は何ですか?

May 28, 2023 am 11:44 AM
redis

単一マシン モード

単一マシン モードredis は非常に簡単で、単一ノードを起動するだけで済み、インストール プロセスには 5 分もかかりません。

redis-benchmarkQPS を介して単純なコマンドをテストすると、10w 以上に到達できます。これは非常に驚くべきことだと言わざるを得ません。

スタンドアロン モードの問題も非常に明白です。高可用性メカニズムが欠如しています。

redis プロセスが停止した場合、プロセスは基盤となるデータベースにのみ侵入できるため、ビジネスにとって非常に危険です。 redis をデータ ストレージとして使用する場合、状況はさらに深刻になり、データが失われる可能性もあります。

マスター/スレーブ モード

したがって、最も基本的な redis デプロイメントでは、1 つ以上の スレーブ (現在は レプリケーションと呼ばれています) が追加されます。 )。

マスター redis で問題が発生した場合、引き継ぐ スレーブを選択できます。

このモードが従来の MySQL マスター/スレーブ モードと同じであるのは残念です。切り替えるのはさらに面倒で、 などの外部ツールの助けが必要です。 keepalived やその他の支援により、切り替え、導入、メンテナンスの難易度が急上昇しました。

keepalived は、VRRP プロトコルに基づく高可用性ソリューションであり、IP ドリフトを通じて高可用性を実現します。説明からわかるように、ネットワーク管理者の参加が必要ですが、これは軽量の redis とは対照的です。

Sentinel モード

Sentinel モードは、keepalived の関数を置き換える追加のプロセスを使用して、redis プロセスの実行可能性を判断します。セントリー モードでは、マスター ノードがダウンすると、スレーブ ノードがいつでもマスター ノードのバックアップとして復帰できます。

しかし、センチネル モードの最大の問題の 1 つは、センチネルが多すぎることであり、これには少なくとも 3 つのノードが必要です。

When arbitrated redis, n/2 1 ノードは確認のために投票する必要があります。これは分散システム (クォーラム) の一般的な慣例でもあります。 Zookeeper と同様に、奇数のセンチネル ノードを作成するのが非常に適切です。

センチネル モードは、センチネル モニター 設定を通じて複数のクラスターを同時に検出でき、クラスターの数が中程度の場合は比較的簡単に使用できます。

しかし、センチネル モードには多くの隠れた落とし穴があります。センチネルの起動などは、マスター が生きている場合にのみ正常に実行できます。また、redis 設定 いくつかの危険なコマンドをブロックするためにファイル内で RENAME が使用されている場合、Sentinel を起動できません。

クライアントが redis に接続すると、redis のインスタンスに直接接続できなくなります。取得するにはセンチネルからサークルを作成する必要があります。いくつかの変更情報。

クラスター モード

クラスター モードは、ここでは最もエレガントな方法であると言えます。必要なのは、複数のピア redis ノードをデプロイし、クライアント コマンドを使用してそれらをグループ化することだけです。

ip=192.169.0.23
./bin/redis-cli --cluster create  $ip:7001 $ip:7002 $ip:7003 $ip:7004 $ip:7005 $ip:7006 --cluster-replicas 1
ログイン後にコピー

これには多くのノードも必要で、通常は 6 つのノード、3 つのマスターと 3 つのスレーブを使用します。ノードの数が 10 を超えると、コラボレーションの柔軟性が低下するため、単一クラスターのストレージとパフォーマンスの制限にすぐに達します。

クラスター モードのいくつかの欠点は非常に隠されています。そのサーバー ノードは非常に安定していますが、一部のコマンドはパフォーマンスに重大な影響を与えます。たとえば、mgetpipeline などです。実行のためにリクエストを複数のノードに分散してから、それらを集約する必要があります。ノードの数が増えると、パフォーマンスが低下します。

以上がRedis クラスター モードとは何ですか?またその利点は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 Windows 11 10.0.22000.100 のインストール時の 0x80242008 エラーの解決策 May 08, 2024 pm 03:50 PM

1. [スタート]メニューを起動し、[cmd]と入力し、[コマンドプロンプト]を右クリックし、[管理者として実行]を選択します。 2. 次のコマンドを順番に入力します (注意してコピーして貼り付けてください): SCconfigwuauservstart=auto、Enter キーを押す SCconfigbitsstart=auto、Enter キーを押す SCconfigcryptsvcstart=auto、Enter キーを押す SCconfigtrustedinstallerstart=auto、Enter キーを押す SCconfigwuauservtype=share、Enter キーを押す netstopwuauserv 、enter netstopcryptS を押す

PHP機能のボトルネックを分析し、実行効率を向上 PHP機能のボトルネックを分析し、実行効率を向上 Apr 23, 2024 pm 03:42 PM

PHP 関数のボトルネックはパフォーマンスの低下につながります。これは、ボトルネック関数を特定し、パフォーマンス分析ツールを使用するという手順で解決できます。結果をキャッシュして再計算を減らします。タスクを並列処理して実行効率を向上させます。文字列の連結を最適化し、代わりに組み込み関数を使用します。カスタム関数の代わりに組み込み関数を使用します。

Golang API のキャッシュ戦略と最適化 Golang API のキャッシュ戦略と最適化 May 07, 2024 pm 02:12 PM

GolangAPI のキャッシュ戦略により、パフォーマンスが向上し、サーバーの負荷が軽減されます。一般的に使用される戦略は、LRU、LFU、FIFO、TTL です。最適化手法には、適切なキャッシュ ストレージの選択、階層型キャッシュ、無効化管理、監視とチューニングが含まれます。実際には、データベースからユーザー情報を取得する API を最適化するために LRU キャッシュが使用されます。それ以外の場合は、データベースからデータを取得した後にキャッシュを更新できます。

PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 PHP 開発におけるキャッシュ メカニズムとアプリケーションの実践 May 09, 2024 pm 01:30 PM

PHP 開発では、キャッシュ メカニズムにより、頻繁にアクセスされるデータがメモリまたはディスクに一時的に保存され、データベース アクセスの数が削減され、パフォーマンスが向上します。キャッシュの種類には主にメモリ、ファイル、データベース キャッシュが含まれます。キャッシュは、組み込み関数またはサードパーティのライブラリ (cache_get() や Memcache など) を使用して PHP に実装できます。一般的な実用的なアプリケーションには、データベース クエリ結果をキャッシュしてクエリ パフォーマンスを最適化したり、ページ出力をキャッシュしてレンダリングを高速化したりすることが含まれます。キャッシュ メカニズムにより、Web サイトの応答速度が効果的に向上し、ユーザー エクスペリエンスが向上し、サーバーの負荷が軽減されます。

PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? PHP 配列のページネーションで Redis キャッシュを使用するにはどうすればよいですか? May 01, 2024 am 10:48 AM

Redis キャッシュを使用すると、PHP 配列ページングのパフォーマンスを大幅に最適化できます。これは、次の手順で実現できます。 Redis クライアントをインストールします。 Redisサーバーに接続します。キャッシュ データを作成し、データの各ページをキー「page:{page_number}」を持つ Redis ハッシュに保存します。キャッシュからデータを取得し、大規模な配列での高コストの操作を回避します。

Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法_Win11 英語 21996 を簡体字中国語 22000 にアップグレードする方法 May 08, 2024 pm 05:10 PM

まず、システム言語を簡体字中国語表示に設定して再起動する必要があります。もちろん、以前に表示言語を簡体字中国語に変更したことがある場合は、この手順をスキップできます。次に、レジストリ regedit.exe の操作を開始し、左側のナビゲーション バーまたは上部のアドレス バーで HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlNlsLanguage に直接移動し、InstallLanguage キーの値と Default キーの値を 0804 に変更します (英語に変更する場合)。まずシステムの表示言語を en-us に設定し、システムを再起動してから、すべてを 0409 に変更します) この時点でシステムを再起動する必要があります。

navicat は redis に接続できますか? navicat は redis に接続できますか? Apr 23, 2024 pm 05:12 PM

はい、Navicat は Redis に接続できます。これにより、ユーザーはキーの管理、値の表示、コマンドの実行、アクティビティの監視、問題の診断が可能になります。 Redis に接続するには、Navicat で「Redis」接続タイプを選択し、サーバーの詳細を入力します。

Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する Win11でダウンロードしたアップデートファイルの探し方_Win11でダウンロードしたアップデートファイルの場所を共有する May 08, 2024 am 10:34 AM

1. まず、デスクトップ上の[このPC]アイコンをダブルクリックして開きます。 2. 次に、マウスの左ボタンをダブルクリックして [C ドライブ] に入ります。システム ファイルは通常、自動的に C ドライブに保存されます。 3. 次に、C ドライブで [windows] フォルダーを見つけ、ダブルクリックしてに入ります。 4. [windows]フォルダーに入ったら、[SoftwareDistribution]フォルダーを見つけます。 5. 入力後、win11 のダウンロード ファイルとアップデート ファイルがすべて含まれている [ダウンロード] フォルダーを見つけます。 6. これらのファイルを削除したい場合は、このフォルダー内で直接削除してください。

See all articles