redis
en mode autonome est très simple. Il vous suffit de démarrer un seul nœud et le processus d'installation ne prend pas plus de 5 minutes. redis
非常简单,你只需要启动一个单一的节点就可以了,安装过程不超过5分钟。
通过redis-benchmark
测试简单的命令,QPS
可达到10w
以上,不得不说非常的让人惊艳了。
单机模式的问题也非常明显。缺乏高可用的机制!
假如redis
进程死了,进程就只能够穿透到底层的数据库中,对业务来说非常的危险。如果你把redis
当作数据存储来用,情况会更加严重,甚至会丢失数据。
所以最基本的redis
部署,都会增加一个或者多个slave
(现在叫replication
)。
当主redis
发生问题的时候,能够选取一个slave
顶上去。
非常可惜的是,这种模式和传统的MySQL
主从一样,切换起来比较蛋疼,需要借助外部的工具,比如keepalived
等辅助进行切换,部署和维护难度直接飙升。
keepalived
是一个基于VRRP
协议来实现的高可用方案,通过 IP 漂移实现高可用。从描述上就可以看出它需要网络管理员的参与,和我们轻量级的redis
背道而驰。
哨兵模式就是使用额外的进程来替换keepalived
的功能,对redis
进程的存活性进行判断。在哨兵模式下,一旦主节点宕机,从节点作为主节点的备份可以随时顶上来。
但哨兵模式一个最大的问题,就是哨兵的数量太多,至少需要3个节点。
对redis
进行仲裁的时候,需要n/2+1
个节点投票才能确认,这也是分布式系统的一般做法 (quorum)。和Zookeeper
类似,哨兵节点做成奇数个,是非常合适的。
哨兵模式可以通过sentinel monitor
配置同时检测多套集群,在集群数量适中的时候,还是比较好用的。
但哨兵模式有很多隐藏的坑,比如哨兵的启动,必须在master
存活的情况下才能正常运行;另外,如果你的redis
配置文件中使用RENAME
屏蔽了一些危险命令时,哨兵也不能够启动。
客户端在连接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个节点,三主三从。一旦节点数量超过10个,协同性就会变得不太灵活,因此,单个集群的存储和性能上限也迅速达到。
集群模式的一些缺点很隐蔽。它的服务端节点倒是非常稳定了,但有些命令会严重影响性能。比如mget
,pipeline
redis-benchmark
, QPS
peut atteindre plus de 10w
, ce qui est très étonnant. 🎜🎜Le problème du mode solo est également très évident. Manque de mécanisme de haute disponibilité ! 🎜🎜Si le processus redis
meurt, le processus ne peut pénétrer que dans la base de données sous-jacente, ce qui est très dangereux pour l'entreprise. Si vous utilisez redis
comme stockage de données, la situation sera plus grave et les données pourraient même être perdues. 🎜🎜Mode maître-esclave🎜🎜Ainsi, le déploiement redis
le plus basique ajoutera un ou plusieurs esclaves
(maintenant appelés réplication
). 🎜🎜Lorsqu'un problème survient avec le maître redis
, vous pouvez choisir un esclave
pour prendre le relais. 🎜🎜Il est dommage que ce mode soit le même que le mode maître-esclave traditionnel MySQL
. Il est plus pénible de changer. Vous devez utiliser des outils externes, tels que keepalivedcode>, etc. pour aider à la commutation, la difficulté de déploiement et de maintenance est montée en flèche. 🎜🎜<code>keepalived
est une solution de haute disponibilité basée sur le protocole VRRP
, qui atteint la haute disponibilité grâce à la dérive IP. Il ressort de la description qu'il nécessite la participation de l'administrateur réseau, ce qui est contraire à notre redis
léger. 🎜🎜Mode Sentinelle🎜🎜Le mode Sentinelle utilise un processus supplémentaire pour remplacer la fonction de keepalived
pour juger de la survie du processus redis
. En mode sentinelle, une fois le nœud maître en panne, le nœud esclave peut revenir à tout moment en secours du nœud maître. 🎜🎜Mais l'un des plus gros problèmes du mode sentinelle est qu'il y a trop de sentinelles, ce qui nécessite au moins 3 nœuds. 🎜🎜Lors de l'arbitrage de redis
, les nœuds n/2+1
doivent voter pour confirmer. C'est également la pratique générale des systèmes distribués (quorum). Semblable à Zookeeper
, il est très approprié de créer un nombre impair de nœuds sentinelles. 🎜🎜Le mode Sentinelle peut détecter plusieurs clusters en même temps grâce à la configuration du moniteur sentinelle
. Il est relativement facile à utiliser lorsque le nombre de clusters est modéré. 🎜🎜Mais le mode sentinelle comporte de nombreux pièges cachés. Par exemple, le démarrage de la sentinelle doit être actif lorsque master
est actif en plus, si votre fichier de configuration redis
; en utilisant RENAME
pour bloquer certaines commandes dangereuses, Sentinel ne peut pas être démarré. 🎜🎜Lorsque le client se connecte à redis
, il ne peut plus se connecter directement à l'instance de redis
. Il doit faire un cercle depuis la sentinelle afin d'obtenir de la modification. information. 🎜🎜Mode cluster🎜🎜Le mode cluster peut être considéré comme la méthode la plus élégante ici. Il vous suffit de déployer plusieurs nœuds redis
homologues, puis d'utiliser les commandes client pour les regrouper. 🎜rrreee🎜Cela nécessite également beaucoup de nœuds, généralement 6 nœuds, trois maîtres et trois esclaves. Dès que le nombre de nœuds dépasse 10, la collaboration devient moins flexible, et donc les limites de stockage et de performances d'un seul cluster sont rapidement atteintes. 🎜🎜Certains inconvénients du mode cluster sont cachés. Son nœud serveur est très stable, mais certaines commandes affecteront sérieusement les performances. Par exemple, mget
, pipeline
, etc. Ils doivent distribuer les requêtes à plusieurs nœuds pour exécution, puis les regrouper. Plus il y a de nœuds, plus les performances sont faibles. 🎜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!