Redis チュートリアル (9): マスター/スレーブ レプリケーション構成例
1. Redis のレプリケーション:
ここで最初に説明する必要があるのは、Redis でのマスター/スレーブ モードの構成は非常に簡単であるということです。このブログを読んでいただければ簡単にできると思います。ここでは、最初にいくつかの理論的な知識を列挙し、次に実際の事例を示します。
次のリストは、Redis レプリケーションの機能と利点を明確に説明しています。
1) 同じマスターは複数のスレーブを同期できます。
2). スレーブは他のスレーブからの接続および同期リクエストも受け入れることができるため、マスターの同期プレッシャーを効果的に軽減できます。したがって、Redis のレプリケーション アーキテクチャはグラフ構造として考えることができます。
3). マスターサーバーは、ノンブロッキング方式でスレーブにサービスを提供します。したがって、マスターとスレーブの同期中も、クライアントはクエリまたは変更リクエストを送信できます。
4). スレーブサーバーも非ブロッキング方式でデータ同期を完了します。同期中にクライアントがクエリリクエストを送信すると、Redis は同期前にデータを返します。
5). マスターの読み取り操作の負荷を軽減するために、スレーブ サーバーは読み取り専用操作サービスをクライアントに提供できますが、書き込みサービスはマスターによって完了する必要があります。それでも、システムの拡張性は大幅に向上しました。
6). マスターはデータ保存操作をスレーブに引き渡すことができるため、この操作を完了するためにマスター内の独立したプロセスが必要なくなります。
2. レプリケーションの仕組み:
スレーブが起動してマスターに接続すると、SYNC コマンドがアクティブに送信されます。その後、マスターはバックグラウンド保存プロセスを開始し、データ セットを変更するために受信したすべてのコマンドを収集します。バックグラウンド プロセスが完了すると、マスターはデータベース ファイル全体をスレーブに転送して完全な同期を完了します。データベース ファイル データを受信した後、スレーブ サーバーはそれを保存し、メモリにロードします。その後、マスターは収集したすべての変更コマンドと新しい変更コマンドを順番にスレーブに送信し続け、今度はスレーブがこれらのデータ変更コマンドを実行して、最終的なデータ同期を達成します。
マスターとスレーブ間のリンクが切断された場合、スレーブは自動的にマスターに再接続できますが、接続が成功すると、完全な同期が自動的に実行されます。
3. レプリケーションを構成する方法:
次の手順を参照してください:
1). 同じマシン上で 2 つの Redis サーバーを同時に起動し、6379 や 6379 などの異なるポートをリッスンすることを検討できます。 6380。
2). スレーブ サーバーでコマンドを実行します:
/> redis-cli -p 6380 #这里我们假设Slave的端口号是6380 redis 127.0.0.1:6380> slaveof 127.0.0.1 6379 #我们假设Master和Slave在同一台主机,Master的端口为6379 OK
上記の方法は、slaveof コマンドの実行後に、redis_6380 が redis_6379 のスレーブになることを保証するだけであり、サービス (redis_6380) が再起動されると、それらの間のレプリケーション関係が終了します。 。
2 つのサーバー間のレプリケーション関係を長期間確保したい場合は、redis_6380 の構成ファイルに次の変更を加えることができます:
/> cd /etc/redis #切换Redis服务器配置文件所在的目录。 /> ls 6379.conf 6380.conf /> vi 6380.conf 将 # slaveof <masterip> <masterport> 改为 slaveof 127.0.0.1 6379
保存して終了します。
これにより、Redis_6380 サービス プログラムが各起動後に Redis_6379 とのレプリケーション接続をアクティブに確立するようになります。
4. 応用例:
ここでは、マスターとスレーブが確立されていると仮定します。
#启动master服务器。 [root@Stephen-PC redis]# redis-cli -p 6379 redis 127.0.0.1:6379> #情况Master当前数据库中的所有Keys。 redis 127.0.0.1:6379> flushdb OK #在Master中创建新的Keys作为测试数据。 redis 127.0.0.1:6379> set mykey hello OK redis 127.0.0.1:6379> set mykey2 world OK #查看Master中存在哪些Keys。 redis 127.0.0.1:6379> keys * 1) "mykey" 2) "mykey2" #启动slave服务器。 [root@Stephen-PC redis]# redis-cli -p 6380 #查看Slave中的Keys是否和Master中一致,从结果看,他们是相等的。 redis 127.0.0.1:6380> keys * 1) "mykey" 2) "mykey2" #在Master中删除其中一个测试Key,并查看删除后的结果。 redis 127.0.0.1:6379> del mykey2 (integer) 1 redis 127.0.0.1:6379> keys * 1) "mykey" #在Slave中查看是否mykey2也已经在Slave中被删除。 redis 127.0.0.1:6380> keys * 1) "mykey"
上記は Redis チュートリアル (9): マスター/スレーブ コピーの構成例の内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











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

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

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

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

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

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

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

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