集群属于水平扩展,原理就是,规定共有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