Redis 6 : Redis Sentinel の設定2022/07/04 |
Redis Sentinel による Redis クラスターの監視設定です。
例として、プライマリーノード 1 台と レプリカノード 2 台で構成した環境へ Sentinel
サーバーを 1 台追加して、プライマリーノードの障害発生時に、マスターロールがレプリカノードに自動フェイルオーバーするように設定します。
| +----------------------+ | +----------------------+ | [ Redis Sentinel ] |10.0.0.30 | 10.0.0.31| [ Redis Primary ] | | dlp.srv.world +----------+----------+ www.srv.world | | | | | | +----------------------+ | +----------------------+ | +----------------------+ | +----------------------+ | [ Redis Replica#1 ] |10.0.0.51 | 10.0.0.52| [ Redis Replica#2 ] | | node01.srv.world +----------+----------+ node02.srv.world | | | | | +----------------------+ +----------------------+ |
[1] |
こちらを参考に プライマリー/レプリカ 全ノードでレプリケーション構成を設定しておきます。
注意点として Sentinel により自動フェイルオーバーした際は、レプリカがプライマリーに、プライマリーがレプリカに切り替わるため、 接続/認証パスワードの設定は全ノードで合わせておく必要があります。 |
[2] | Sentinel による監視設定は、障害発生時には Sentinel により各ノードの [redis.conf] の書き換えが実行されてプライマリー/レプリカが切り替わるため、基本的には事前にプライマリー/レプリカ上での手動設定変更は必要ありませんが、 SELinux を有効にしている場合は、[redis.conf] を変更するための許可ルールの追加が必要になります。以下の許可ルールの追加をプライマリー/レプリカ全ノードで実施します。 |
[root@www ~]# semanage fcontext -a -t redis_conf_t /etc/redis/redis.conf [root@www ~]# restorecon /etc/redis/redis.conf |
[3] | Sentinel サーバーをセットアップします。 |
[root@dlp ~]#
dnf -y install redis
[root@dlp ~]#
vi /etc/redis/sentinel.conf # 26行目 : 変更 (サービスとして起動) daemonize yes
# 84行目 : 変更 # [sentinel monitor (任意の名称) (プライマリーノードの IP) (プライマリーノードのポート) (Quorum)] # Quorum ⇒ 指定した数の Sentinel サーバーがプライマリーノードがダウンしたと判断した場合にフェイルオーバーする sentinel monitor mymaster 10.0.0.31 6379 1
# 104行目 : プライマリーノードの認証パスワードを追記
sentinel auth-pass mymaster password
# 125行目 : プライマリーノードがダウンしたと判断する時間 (デフォルトは 30秒) sentinel down-after-milliseconds mymaster 30000 # 200行目 : フェイルオーバー中に設定変更するレプリカの数 sentinel parallel-syncs mymaster 1 systemctl enable --now redis-sentinel |
[4] | 以上で設定完了です。Sentinel サーバーで状態の確認をします。 また、プライマリーノードの Redis を手動で停止させる等して、正常にフェイルオーバーするか等々も確認しておくよいでしょう。 |
[root@dlp ~]# redis-cli -p 26379 # [mymaster] のプライマリーノード確認 127.0.0.1:26379> sentinel get-master-addr-by-name mymaster 1) "10.0.0.31" 2) "6379" # [mymaster] のプライマリーノードの詳細 127.0.0.1:26379> sentinel master mymaster 1) "name" 2) "mymaster" 3) "ip" 4) "10.0.0.31" 5) "port" 6) "6379" 7) "runid" 8) "bf90ece894849e3ba8444ecca915d41ec33bf1a9" 9) "flags" 10) "master" ..... ..... # [mymaster] のレプリカ確認 127.0.0.1:26379> sentinel slaves mymaster 1) 1) "name" 2) "10.0.0.52:6379" 3) "ip" 4) "10.0.0.52" 5) "port" 6) "6379" 7) "runid" 8) "5bd2c044bc0500a2dc2366e8886b66a11f25c16c" 9) "flags" 10) "slave" ..... ..... 2) 1) "name" 2) "10.0.0.51:6379" 3) "ip" 4) "10.0.0.51" 5) "port" 6) "6379" 7) "runid" 8) "953906f02e74200a929e52cb49c034249323609d" 9) "flags" 10) "slave" ..... ..... |
Sponsored Link |