reids集群

集群属于水平扩展,原理就是,规定共有16384个插槽,插槽的作用就是存储键信息,将几个数据库设置成集群之后,每个节点(就是每个集群中主数据库)负责一部分插槽

集群需要至少3个主数据库才能运行,为每一个数据库配一个配置文件,在每个配置文件中存在cluster-config-file redis-6380.conf  保存的是当前节点的集群状态

redis-trib.rb是一个集群的辅助工具

向集群中增加节点:cluster meet 集群中的IP 与之对应的端口

键与插槽的对应关系:redis将每个键的有效部分(“{}”之间包括的,没有大括号的话,就是全部键值)进行CRC16算法计算出散列值,然后对16384进行取余,这样就可以将其分配到对应的插槽中


插槽与节点之间的关系:

1.插槽之前没有分配过,现在想将其分配给节点

cluster addslots 插槽

cluster slots 可以查看插槽的分配情况


2.插槽之前分配过,现在想将其移动到制指定的节点

cluster setslot 插槽号 node 新节点的运行ID(看书吧)


获取与插槽对应的节点 ,某个键可能不存在你操作的节点上,这时需要为其指定键所在的节点,redis-cli -c -p 6380这种集群模式的自动转移

有些客户端支持自动转移


故障恢复

集群中的节点A,会每隔一秒随机获得5个节点,对5各节点中最久没有响应的节点发送ping命令,如果没有回应,他会通知其他的节点,当有超过一半以上的节点认为这个节点失效了,则集群中认为其已经下线,这时就需要该下线的数据库的从数据变成主数据库,如果他没有从数据库,那么集群无法继续工作;如果想让集群在这种情况继续工作,可以设置cluster-require-full-coverage yes

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值