Maison >développement back-end >tutoriel php >Implémentation du cluster Redis et appels en utilisant php
Cet article présente l'implémentation du cluster redis et l'utilisation de php pour l'appeler. J'aimerais le partager avec vous. Les amis dans le besoin peuvent s'y référer
Construire un cluster redis1. Explication du concept
Redis 3.0 et les versions ultérieures prennent en charge les clusters redis-cluster. Chaque nœud enregistre les données et l'état complet du cluster, et chaque nœud est connecté à tous les autres nœuds. Le schéma d'architecture du redis-cluster est le suivant :
Ses caractéristiques structurelles :
1、所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽。 2、节点的fail是通过集群中超过半数的节点检测失效时才生效。 3、客户端与redis节点直连,不需要中间proxy层.客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可。 4、redis-cluster把所有的物理节点映射到[0-16383]slot上(不一定是平均分配),cluster 负责维护nodeslotvalue。 5、Redis集群预分好16384个桶,当需要在 Redis 集群中放置一个 key-value 时,根据 CRC16(key) mod 16384的值,决定将一个key放到哪个桶中。
现在我们是三个主节点分别是:A, B, C 三个节点,它们可以是一台机器上的三个端口,也可以是三台不同的服务器。那么,采用哈希槽 (hash slot)的方式来分配16384个slot 的话,它们三个节点分别承担的slot 区间是: 节点A覆盖0-5460; 节点B覆盖5461-10922; 节点C覆盖10923-16383.ne peuvent pas être comprises,,,,
获取数据: 如果存入一个值,按照redis cluster哈希槽的算法: CRC16('key')384 = 6782。 那么就会把这个key 的存储分配到 B 上了。同样,当我连接(A,B,C)任何一个节点想获取'key'这个key时,也会这样的算法,然后内部跳转到B节点上获取数据2. Mode maître-esclave du cluster Redis
redis cluster 为了保证数据的高可用性,加入了主从模式,一个主节点对应一个或多个从节点,主节点提供数据存取,从节点则是从主节点拉取数据备份,当这个主节点挂掉后,就会有这个从节点选取一个来充当主节点,从而保证集群不会挂掉。并且如果之前的旧主节点恢复正常时。3. Construction du cluster Redis
上面那个例子里, 集群有ABC三个主节点, 如果这3个节点都没有加入从节点,如果B挂掉了,我们就无法访问整个集群了。A和C的slot也无法访问。 所以我们在集群建立的时候,一定要为每个主节点都添加了从节点, 比如像这样, 集群包含主节点A、B、C, 以及从节点A1、B1、C1, 那么即使B挂掉系统也可以继续正确工作。 B1节点替代了B节点,所以Redis集群将会选择B1节点作为新的主节点,集群将会继续正确地提供服务。 当B重新开启后,它就会变成B1的从节点。 不过需要注意,如果节点B和B1同时挂了,Redis集群就无法继续正确地提供服务了。Eh bien, tous nécessitent au moins 6 services Redis.
集群中至少应该有奇数个节点,所以至少有三个节点,每个节点至少有一个备份节点,所以下面使用6节点(主节点、备份节点由redis-cluster集群确定)。Démarrez ensuite ces 6 services redis sur cette machine, mais pensez à modifier la configuration avant de démarrer.
port 7000 //端口7000,7002,7003 bind 10.93.84.53 //默认ip为127.0.0.1 需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群daemonize yes //redis后台运行pidfile ./redis_7000.pid //pidfile文件对应7000,7001,7002cluster-enabled yes //开启集群 把注释#去掉cluster-config-file nodes.conf //集群的配置 配置文件首次启动自动生成 7000,7001,7002cluster-node-timeout 15000 //请求超时 默认15秒,可自行设置appendonly yes //aof日志开启 有需要就开启,它会每次写操作都记录一条日志Installer l'environnement Ruby
yum install ruby yum install rubygems gem install redis-3.2.2.gemEnfin, nous utilisons redis-trib.rb pour créer un cluster redis. Utilisez le paramètre create command –replicas 1 pour créer un nœud esclave pour chaque nœud maître, une paire de deux, le premier est le maître et le second est l'esclave.
ps -ef | grep redisUtilisez redis-cli pour les tests Vous devez ajouter le paramètre -c pour vous connecter en mode cluster.
./redis-trib.rb create --replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006Vous devez ajouter le paramètre -c, ce qui signifie que la connexion est en mode cluster.
redis-cli -cÀ ce stade, le cluster Redis est établi avec succès.
Mais ici, je n'ai besoin que de 6 ports pour les tests locaux. Pour être réaliste, au moins deux machines sont nécessaires. Comment faisons-nous la sécurité ?
1. Modifiez redis.conf et remplacez l'option de liaison par l'adresse IP LAN actuelle
2. Configurez le pare-feu pour autoriser uniquement l'accès à un autre serveur Redis. Bien entendu, l'adresse IP du serveur d'applications doit également être autorisée. accéder. . . Sinon, le programme ne pourra pas se connecter au service Redis, ce qui est une perte de temps. . . .
//先关掉6379(redis服务使用的端口)iptables -I INPUT -p tcp --dport 6379 -j DROP //允许192.168.1.0这个机器进行访问本机的6379端口iptables -I INPUT -s 192.168.1.0 -p tcp --dport 6379 -j ACCEPTUtilisez d'abord php –ri redis pour afficher la version étendue de redis. Doit être supérieur à la version 3.0.
Référence
Le deuxième paramètre n'a besoin que d'un seul nœud dans le cluster, vous n'avez pas besoin de tout remplir
$obj_cluster = new RedisCluster(NULL, ['127.0.0.1:6380']);echo $obj_cluster->get('name1');
Recommandations associées :
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!