#ノード
ホスト |
ポート |
追加構成 |
|
node01
127.0.0.1 |
26380 |
センチネル モニター mymaster 127.0.0.1 6380 2 |
|
node02
127.0.0.1 |
26381 |
センチネル モニター mymaster 127.0.0.1 6380 2 |
|
node03
127.0.0.1 |
26382 |
センチネル モニター mymaster 127.0.0.1 6380 2 |
|
(2) サービス設定
1. Redis インスタンス
ノードの初期設定ファイルは、デフォルトの設定ファイルをテンプレートとして使用します。
node01 と node02 が設定ファイルを初期化すると、ノード間のマスター/スレーブ関係が表示され、次の設定が追加されます:
replicaof 127.0.0.1 6380
2. Sentinel サービス
初期設定ノードの設定ファイルは次のとおりです。 デフォルトの設定ファイルはテンプレートです。
node01、node02、node03 が設定ファイルを初期化した後、次の設定を追加します。
sentinel monitor mymaster 127.0.0.1 6381 2
(3) サービス管理
テストまたは学習する場合は、次の設定を追加することをお勧めします。フォアグラウンド プロセスを使用してサービスを管理すると、単一障害点をシミュレートしたり、ログを表示したり、マスター/スレーブの切り替えを観察したりするのに便利です。
本番環境では、スーパーバイザーを使用してサービスを管理することをお勧めします。これは、管理が簡単なだけでなく、異常終了後にサービスを自動的に再起動できます。高可用性シナリオでは 3 台の物理マシンが使用されます。
1. Redis インスタンス
/usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis80.conf --port 6380 --save '' --daemonize no
/usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis81.conf --port 6381 --save '' --daemonize no
/usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis82.conf --port 6382 --save '' --daemonize no
2. Sentinel サービス
/usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel280.conf --port 26380 --daemonize no
/usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel281.conf --port 26381 --daemonize no
/usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel282.conf --port 26382 --daemonize no
3. クライアント統合
クライアント実装とは、SpringBoot に基づく統合を指します。実装ステップ: まず、基礎としての統合を完了し、次に、運用ニーズに基づいて新しい機能を追加します。
(1) 基本統合
基本統合の内容は、Java クライアントを使用して高可用性センチネル モード Redis サービスに接続し、単一ノード障害の通常動作の要件を達成することです。サービス。
1. グローバル設定ファイル
グローバル設定ファイルに追加される設定情報は次のとおりです: master
パラメータはセンチネル サービス名で、これがデフォルト値です。nodes
パラメータはセンチネル サービス リスト (Redis インスタンス サービス リストではありません); database
パラメータはデータベースです。
spring:
redis:
database: 0
sentinel:
nodes: 192.168.181.171:26380,192.168.181.171:26381,192.168.181.171:26382
master: mymaster
2. 統合構成
は SpringBoot システムに統合されています。中心となるのは、LettuceConnectionFactory
接続ファクトリを作成することです。Redis 接続ファクトリを通じて、スムーズに接続ファクトリを作成できます。スプリング システムの他の部分に継承されます。
@Configuration
public class RedisSentinelConfig {
@Autowired
private RedisProperties redisProperties;
@Bean
public RedisConnectionFactory lettuceConnectionFactory() {
RedisProperties.Sentinel sentinel = redisProperties.getSentinel();
HashSet<String> nodes = new HashSet<>(sentinel.getNodes());
String master = sentinel.getMaster();
RedisSentinelConfiguration config = new RedisSentinelConfiguration(master, nodes);
config.setDatabase(redisProperties.getDatabase());
return new LettuceConnectionFactory(config);
}
}
(2) 読み取りと書き込みの分離
基本的な統合は、高可用性 Redis サービスのプロセスのみを実装します。運用環境では、他の構成を追加する必要があります: カスタム接続の変更データベースのシリアル番号、接続の承認、接続プールの構成、読み取りと書き込みの分離。
高可用性を前提として、メインライブラリが書き込みリクエストを完了し、スレーブライブラリが読み出しリクエストを完了する(スレーブライブラリは書き込みを許可しない)という、読み出しと書き込みの分離という特徴が生まれます。
rree