Redis集群节点的选举(实验)
admin
2023-05-21 06:42:53
0

Redis集群节点的选举:

    当master挂掉之后,就会在该集群中的slave中选取一个来代替mater角色,

    从而保证redis集群slot的完整性。

    如果其中一个mster和它的slave都挂掉后,会导致slot不完整,整个集群都会挂掉。


集群节点信息:

    192.168.2.200:6379> cluster nodes

    3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69 192.168.2.201:6379 master - 0 1527145806504 5 connected 10923-16383

    2faf68564a70372cfc06c1afff197019cc6a39f3 192.168.2.201:6380 slave 3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69 0 1527145805495 5 connected

    227f51028bbe827f27b4e40ed7a08fcc7d8df969 192.168.2.200:6380 slave 098e7eb756b6047fde988ab3c0b7189e1724ecf5 0 1527145804485 4 connected

    5844b4272c39456b0fdf73e384ff8c479547de47 192.168.2.200:6379 myself,master - 0 0 3 connected 5461-10922

    7119dec91b086ca8fe69f7878fa42b1accd75f0f 192.168.2.100:6380 slave 5844b4272c39456b0fdf73e384ff8c479547de47 0 1527145802468 3 connected

    098e7eb756b6047fde988ab3c0b7189e1724ecf5 192.168.2.100:6379 master - 0 1527145803476 1 connected 0-5460


新建3个key:

    192.168.2.200:6379> set name zhangsan

    OK

    192.168.2.200:6379> set age 26

    -> Redirected to slot [741] located at 192.168.2.100:6379

    OK

    192.168.2.100:6379> set home beijing

    -> Redirected to slot [10814] located at 192.168.2.200:6379

    OK


模拟192.168.2.100:6379挂掉:

    # ps -ef |grep redis

        root      19023      1  0 15:05 ?        00:00:01 redis-server 192.168.2.100:6379 [cluster]

        root      19030      1  0 15:05 ?        00:00:01 redis-server 192.168.2.100:6380 [cluster]

        root      19127   2912  0 15:13 pts/0    00:00:00 grep --color=auto redis

    # kill 19023


查看集群节点状态:可以看到集群中的一个slave的角色变成了master

    # redis-trib.rb check 192.168.2.200:6379

    >>> Performing Cluster Check (using node 192.168.2.200:6379)

    M: 5844b4272c39456b0fdf73e384ff8c479547de47 192.168.2.200:6379

    slots:5461-10922 (5462 slots) master

    1 additional replica(s)

    M: 3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69 192.168.2.201:6379

    slots:10923-16383 (5461 slots) master

    1 additional replica(s)

    S: 2faf68564a70372cfc06c1afff197019cc6a39f3 192.168.2.201:6380

    slots: (0 slots) slave

    replicates 3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69

    M: 227f51028bbe827f27b4e40ed7a08fcc7d8df969 192.168.2.200:6380

    slots:0-5460 (5461 slots) master

    0 additional replica(s)

    S: 7119dec91b086ca8fe69f7878fa42b1accd75f0f 192.168.2.100:6380

    slots: (0 slots) slave

    replicates 5844b4272c39456b0fdf73e384ff8c479547de47

    [OK] All nodes agree about slots configuration.

    >>> Check for open slots...

    >>> Check slots coverage...

    [OK] All 16384 slots covered.


查看数据是否存在:

    # redis-cli -h 192.168.2.200 -p 6380 -c

        192.168.2.200:6380> keys *

        1) "age"


模拟恢复故障节点:

    # redis-server redis.conf


查看集群节点状态:故障节点恢复后,是变成master还是slave?

    # redis-trib.rb check 192.168.2.200:6379

    >>> Performing Cluster Check (using node 192.168.2.200:6379)

    M: 5844b4272c39456b0fdf73e384ff8c479547de47 192.168.2.200:6379

   slots:5461-10922 (5462 slots) master

   1 additional replica(s)

    M: 3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69 192.168.2.201:6379

   slots:10923-16383 (5461 slots) master

   1 additional replica(s)

    S: 2faf68564a70372cfc06c1afff197019cc6a39f3 192.168.2.201:6380

   slots: (0 slots) slave

   replicates 3ff3a74f9dc41f8bc635ab845ad76bf77ffb0f69

    M: 227f51028bbe827f27b4e40ed7a08fcc7d8df969 192.168.2.200:6380

   slots:0-5460 (5461 slots) master

   1 additional replica(s)

    S: 7119dec91b086ca8fe69f7878fa42b1accd75f0f 192.168.2.100:6380

   slots: (0 slots) slave

   replicates 5844b4272c39456b0fdf73e384ff8c479547de47

    S: 098e7eb756b6047fde988ab3c0b7189e1724ecf5 192.168.2.100:6379

   slots: (0 slots) slave

   replicates 227f51028bbe827f27b4e40ed7a08fcc7d8df969

    [OK] All nodes agree about slots configuration.

    >>> Check for open slots...

    >>> Check slots coverage...

    [OK] All 16384 slots covered.


总结:master:192.168.2.100:6379 宕机后,

      slave:192.168.2.200:6380 代替了其位置,变成了master角色。

      当192.168.2.100:6379故障恢复后,并没有恢复到master的角色,

      而是充当了slave角色。


相关内容

热门资讯

黄三、李四是谁?多部门回应拆迁... 澎湃新闻记者 陈绪厚拆迁公告中产权人的姓名为“黄三”、“李四”,广州市荔湾区政府国有土地上房屋征收办...
专注大模型的定制软件开发公司解... 专注大模型,定制开发如何避坑?这家公司提供了不一样的思路 当AI的浪潮席卷而来,几乎每一家企业都在思...
外交部回应特朗普涉台表态 新华社北京5月18日电(记者冯歆然、董雪)就美国总统特朗普涉台表态,外交部发言人郭嘉昆18日在例行记...
特朗普访华后高市早苗与其通话,... 澎湃新闻记者 杨文钦 朱郑勇5月18日,外交部发言人郭嘉昆主持例行记者会。迪拜中阿卫视记者提问,在特...
谷歌前CEO毕业典礼谈AI惹争... 来源:环球网 【环球网科技综合报道】5月18日消息,据据 NBC News 报道,前谷歌CEO埃里...
【图片故事】从“打工妹”到隐形... 来源:滚动播报 (来源:工人日报) 近日,在广东鼎泰高科技术股份有限公司总部实验室,王馨(右二)与研...
嘉义县长“在野大联盟”人选呼之... 海峡导报综合报道 年底嘉义县长选举开打,民进党民代蔡易余已积极备战,以国民党为首的在野势力打算以“在...
电视指示灯亮却打不开什么原因 上次关机时电视处于待机状态,所以打开电视电源开关后,电视仍然处于待机状态,屏幕没有显示,这时需要使用...
冰箱压缩机ptc启动器判断好坏 第一步需要将PTC启动器连接,首先把启动器的插头连接到电源插座上,然后仔细查看冰箱内照明灯的明暗状况...
冰柜压缩机启动器都一样的吗 不是,二者不可以通用的,更不可以随意更换。冰箱的启动器都是有专门的人员进行配对的,千万不要尝试自行更...