Maison > base de données > Redis > Parlons du mode sentinelle dans Redis

Parlons du mode sentinelle dans Redis

青灯夜游
Libérer: 2021-08-19 09:02:43
avant
2161 Les gens l'ont consulté

Cet article vous présentera le mode sentinelle dans Redis. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Parlons du mode sentinelle dans Redis

La méthode de technologie de commutation maître-esclave est la suivante :

  • Lorsque le serveur maître est en panne, vous devez passer manuellement du serveur esclave (slaveof no one) au serveur maître-esclave, ce qui nécessite une intervention manuelle.
  • Cela prend du temps et est laborieux, mais entraînera également une indisponibilité du service pendant un certain temps. Ce n’est pas une approche recommandée.
  • Plus de temps, nous priorisons le mode Sentinel, qui est le mode grand public des applications d'entreprise actuelles. Redis Sentinel est une implémentation hautement disponible de Redis.
  • Sentinel est un outil permettant de gérer plusieurs instances Redis. Il peut surveiller, notifier Redis et automatiser le basculement.

Concepts de base de Redis Sentinel

Schéma schématique de la réplication maître-esclave et de l'architecture haute disponibilité Sentinel

Parlons du mode sentinelle dans Redis

Architecture Redis Sentinel

Parlons du mode sentinelle dans Redis

Les principales fonctions de Redis Sentinel Les principales fonctions de Sentinel incluent :

Détection de survie du nœud maître, détection du fonctionnement maître-esclave, basculement automatique et commutation maître-esclave.

  • La configuration minimale des balises de Redis est un maître et un esclave ;
  • Le système Sentinel de Redis peut être utilisé pour gérer plusieurs serveurs Redis.
  • Le système peut effectuer les quatre tâches suivantes :

1 Surveillance : Sentinel vérifiera en permanence si le serveur maître et l'esclave. les serveurs sont normaux. Exécuter ;
2, Notification : en cas de problème avec le serveur Redis surveillé, Sentinel enverra une notification à l'administrateur ou à d'autres applications via un script API ; 🎜>3, Basculement automatique : lorsque le nœud principal ne fonctionne pas correctement, Sentinel lance une opération de basculement automatique. Il met à niveau l'un des nœuds esclaves dans une relation maître-esclave avec le nœud maître défaillant vers le nouveau nœud maître et pointe les autres nœuds esclaves vers le nouveau nœud maître
4 Fournisseur de configuration : En mode Redis Sentinel, lors de l'initialisation de l'application client, elle se connectera à la collection de nœuds Sentinel pour obtenir les informations du nœud maître

Comment fonctionne Redis Sentinel

 ;

Lorsque le nœud sentinelle se connecte à l'instance Redis, il créera deux connexions : cmd et pub/sub. Sentinel envoie des commandes à Redis via des connexions cmd et à d'autres instances Sentinel sur l'instance Redis via des connexions pub/sub.
  • Commandes permettant à Sentinel d'interagir avec les maîtres et les esclaves Redis
  • Chaque Sentinel envoie une commande PING chaque seconde à ses maîtres, esclaves et autres instances Sentinel connus.

Parlons du mode sentinelle dans Redis

Si une instance prend plus de temps que le temps spécifié par down depuis la dernière réponse valide (en millisecondes) à la commande PING, alors Sentinel L'instance sera marqué comme
    Subjectivement hors ligne
  • .

Parlons du mode sentinelle dans Redis

Si le maître est marqué comme déconnexion subjective, tous les nœuds Sentinel du maître seront surveillés pour confirmer que le maître a effectivement entré une déconnexion subjective une fois par seconde Statut de déconnexion.

Parlons du mode sentinelle dans Redis

Si le maître est marqué pour une déconnexion subjective et qu'il y a suffisamment de sentinelles dans le délai spécifié (au moins le nombre spécifié dans le fichier de configuration) Si cela est conforme à ce jugement, le serveur principal sera marqué comme objectivement hors ligne.

Parlons du mode sentinelle dans Redis

Généralement, chaque Sentinelle envoie des commandes INFO à tous ses maîtres et esclaves connus toutes les 10 secondes. Lorsque Sentinel marque un serveur maître comme hors ligne, la fréquence à laquelle Sentinel envoie des commandes INFO à tous les serveurs esclaves du serveur maître hors ligne passe d'une fois toutes les 10 secondes à une fois toutes les secondes.

Parlons du mode sentinelle dans Redis

Sentinel négocie le statut du nœud maître avec d'autres sentinelles. Si le nœud maître est dans l'état SDOWN, le vote sélectionnera automatiquement un nouveau nœud maître. Pointez les nœuds esclaves restants vers le nouveau nœud maître
    pour la réplication des données
  • .

  • S'il n'y a pas assez de sentinelles pour permettre au maître de se déconnecter , le statut de déconnexion objectif du maître sera supprimé. Lorsque le maître renvoie une réponse valide à la commande PING de Sentinel, l'état subjectif hors ligne du maître est supprimé.

Parlons du mode sentinelle dans Redis

  • note

Un cluster Redis Sentinel robuste doit utiliser au moins trois instances Sentinel, Et assurez-vous de placer ces instances sur différentes machines, voire sur différentes zones physiques.
Sentinel ne peut pas garantir une forte cohérence. Sentinel est pris en charge dans les bibliothèques d'applications clientes courantes.
Sentinel nécessite des tests et une observation constants pour garantir une haute disponibilité

Tests

  • Créer un fichier de configuration

Parlons du mode sentinelle dans Redis

La configuration simple est la suivante :

port 16379  # 哨兵端口号
daemonize yes
sentinel monitor master 127.0.0.1 6379 1    # 监视master
protected-mode no
logfile "/usr/local/bin/sentinel-1/sentinel-1.log"   # 日志文件
Copier après la connexion
  • Démarrez d'abord redis pour configurer le cluster, démarrez redis-cli, définissez 6379 en tant que maître

1Parlons du mode sentinelle dans Redis

  • Redémarrer la sentinelle
sudo redis-sentinel sentinel-1/sentinel.conf
Copier après la connexion

1Parlons du mode sentinelle dans Redis

  • Fermer 6379

13 .png

  • Vérifiez les rôles des deux autres redis-cli

1Parlons du mode sentinelle dans Redis

  • Redémarrer 6379

1Parlons du mode sentinelle dans Redis

  • Afficher le journal sentinelle

1Parlons du mode sentinelle dans Redis

sentinelle Description du .conf

# Example sentinel.conf

# *** IMPORTANT ***
# 绑定IP地址
# bind 127.0.0.1 192.168.1.1
# 保护模式(是否禁止外部链接,除绑定的ip地址外)
# protected-mode no

# port <sentinel-port>
# 此Sentinel实例运行的端口
port 26379

# 默认情况下,Redis Sentinel不作为守护程序运行。 如果需要,可以设置为 yes。
daemonize no

# 启用守护进程运行后,Redis将在/var/run/redis-sentinel.pid中写入一个pid文件
pidfile /var/run/redis-sentinel.pid

# 指定日志文件名。 如果值为空,将强制Sentinel日志标准输出。守护进程下,如果使用标准输出进行日志记录,则日志将发送到/dev/null
logfile ""

# sentinel announce-ip <ip>
# sentinel announce-port <port>
#
# 上述两个配置指令在环境中非常有用,因为NAT可以通过非本地地址从外部访问Sentinel。
#
# 当提供announce-ip时,Sentinel将在通信中声明指定的IP地址,而不是像通常那样自动检测本地地址。
#
# 类似地,当提供announce-port 有效且非零时,Sentinel将宣布指定的TCP端口。
#
# 这两个选项不需要一起使用,如果只提供announce-ip,Sentinel将宣告指定的IP和“port”选项指定的服务器端口。
# 如果仅提供announce-port,Sentinel将通告自动检测到的本地IP和指定端口。
#
# Example:
#
# sentinel announce-ip 1.2.3.4

# dir <working-directory>
# 每个长时间运行的进程都应该有一个明确定义的工作目录。对于Redis Sentinel来说,/tmp就是自己的工作目录。
dir /tmp

# sentinel monitor <master-name> <ip> <redis-port> <quorum>
#
# 告诉Sentinel监听指定主节点,并且只有在至少<quorum>哨兵达成一致的情况下才会判断它 O_DOWN 状态。
#
#
# 副本是自动发现的,因此您无需指定副本。
# Sentinel本身将重写此配置文件,使用其他配置选项添加副本。另请注意,当副本升级为主副本时,将重写配置文件。
#
# 注意:主节点(master)名称不能包含特殊字符或空格。
# 有效字符可以是 A-z 0-9 和这三个字符 ".-_".
sentinel monitor mymaster 127.0.0.1 6379 2

# 如果redis配置了密码,那这里必须配置认证,否则不能自动切换
# Example:
#
# sentinel auth-pass mymaster MySUPER--secret-0123passw0rd

# sentinel down-after-milliseconds <master-name> <milliseconds>
#
# 主节点或副本在指定时间内没有回复PING,便认为该节点为主观下线 S_DOWN 状态。
#
# 默认是30秒
sentinel down-after-milliseconds mymaster 30000

# sentinel parallel-syncs <master-name> <numreplicas>
#
# 在故障转移期间,多少个副本节点进行数据同步
sentinel parallel-syncs mymaster 1

# sentinel failover-timeout <master-name> <milliseconds>
#
# 指定故障转移超时(以毫秒为单位)。 它以多种方式使用:
#
# - 在先前的故障转移之后重新启动故障转移所需的时间已由给定的Sentinel针对同一主服务器尝试,是故障转移超时的两倍。
#
# - 当一个slave从一个错误的master那里同步数据开始计算时间。直到slave被纠正为向正确的master那里同步数据时。
#
# - 取消已在进行但未生成任何配置更改的故障转移所需的时间
#
# - 当进行failover时,配置所有slaves指向新的master所需的最大时间。
#   即使过了这个超时,slaves依然会被正确配置为指向master。
#
# 默认3分钟
sentinel failover-timeout mymaster 180000

# 脚本执行
#
# sentinel notification-script和sentinel reconfig-script用于配置调用的脚本,以通知系统管理员或在故障转移后重新配置客户端。
# 脚本使用以下规则执行以进行错误处理:
#
# 如果脚本以“1”退出,则稍后重试执行(最多重试次数为当前设置的10次)。
#
# 如果脚本以“2”(或更高的值)退出,则不会重试执行。
#
# 如果脚本因为收到信号而终止,则行为与退出代码1相同。
#
# 脚本的最长运行时间为60秒。 达到此限制后,脚本将以SIGKILL终止,并重试执行。

# 通知脚本
#
# sentinel notification-script <master-name> <script-path>
#
# 为警告级别生成的任何Sentinel事件调用指定的通知脚本(例如-sdown,-odown等)。
# 此脚本应通过电子邮件,SMS或任何其他消息传递系统通知系统管理员 监控的Redis系统出了问题。
#
# 使用两个参数调用脚本:第一个是事件类型,第二个是事件描述。
#
# 该脚本必须存在且可执行,以便在提供此选项时启动sentinel。
#
# 举例:
#
# sentinel notification-script mymaster /var/redis/notify.sh

# 客户重新配置脚本
#
# sentinel client-reconfig-script <master-name> <script-path>
#
# 当主服务器因故障转移而变更时,可以调用脚本执行特定于应用程序的任务,以通知客户端,配置已更改且主服务器地址已经变更。
#
# 以下参数将传递给脚本:
#
# <master-name> <role> <state> <from-ip> <from-port> <to-ip> <to-port>
#
# <state> 目前始终是故障转移 "failover"
# <role> 是 "leader" 或 "observer"
#
# 参数 from-ip, from-port, to-ip, to-port 用于传递主服务器的旧地址和所选副本的新地址。
#
# 举例:
#
# sentinel client-reconfig-script mymaster /var/redis/reconfig.sh

# 安全
# 避免脚本重置,默认值yes
# 默认情况下,SENTINEL SET将无法在运行时更改notification-script和client-reconfig-script。
# 这避免了一个简单的安全问题,客户端可以将脚本设置为任何内容并触发故障转移以便执行程序。
sentinel deny-scripts-reconfig yes

# REDIS命令重命名
#
#
# 在这种情况下,可以告诉Sentinel使用不同的命令名称而不是正常的命令名称。
# 例如,如果主“mymaster”和相关副本的“CONFIG”全部重命名为“GUESSME”,我可以使用:
#
# SENTINEL rename-command mymaster CONFIG GUESSME
#
# 设置此类配置后,每次Sentinel使用CONFIG时,它将使用GUESSME。 请注意,实际上不需要尊重命令案例,因此在上面的示例中写“config guessme”是相同的。
#
# SENTINEL SET也可用于在运行时执行此配置。
#
# 为了将命令设置回其原始名称(撤消重命名),可以将命令重命名为它自身:
#
# SENTINEL rename-command mymaster CONFIG CONFIG
Copier après la connexion

Pour plus de connaissances liées à la programmation, veuillez visiter : Enseignement de la programmation ! !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:juejin.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal