Docker搭建Redis集群

 

 Redis服务启动命令参数代表意义

 

启动六台Redis服务器

docker run -d --name redis-node-1 --net host --privileged=true -v /data/redis/share/redis-node-1:/data redis --cluster-enabled yes --appendonly yes --port 6381
docker run -d --name redis-node-2 --net host --privileged=true -v /data/redis/share/redis-node-2:/data redis --cluster-enabled yes --appendonly yes --port 6382
docker run -d --name redis-node-3 --net host --privileged=true -v /data/redis/share/redis-node-3:/data redis --cluster-enabled yes --appendonly yes --port 6383
docker run -d --name redis-node-4 --net host --privileged=true -v /data/redis/share/redis-node-4:/data redis --cluster-enabled yes --appendonly yes --port 6384
docker run -d --name redis-node-5 --net host --privileged=true -v /data/redis/share/redis-node-5:/data redis --cluster-enabled yes --appendonly yes --port 6385
docker run -d --name redis-node-6 --net host --privileged=true -v /data/redis/share/redis-node-6:/data redis --cluster-enabled yes --appendonly yes --port 6386

 

进入容器并构建主从关系

docker exec -it redis-node-1 /bin/bash  #进入容器

#设置主从关系
redis-cli --cluster create 192.168.254.128:6381 192.168.254.128:6382 192.168.254.128:6383 192.168.254.128:6384 192.168.254.128:6385 192.168.254.128:6386 --cluster-replicas 1

 

  使用 INFO 风格的形式展现了关于Redis集群的重要参数

 

redis-cli -p 6381  #进入redis服务

 

 

 

  cluster nodes 命令查看集群的节点信息

 

 

 

成功

redis-cli -p 6381 -c  #进入redis服务

-c开启reidis cluster模式,连接redis cluster节点时候使用。

 

slots  

  一个 Redis 集群包含 16384 个插槽(hash slot), 数据库中的每个键都属于这 16384 个插槽的其中一个,

  集群使用公式 CRC16(key) % 16384 来计算键 key 属于哪个槽, 其中 CRC16(key) 语句用于计算键 key CRC16 校验和

  集群中的每个节点负责处理一部分插槽。 举个例子, 如果一个集群可以有主节点, 其中:

  节点 A 负责处理 号至 5460 号插槽。

  节点 B 负责处理 5461 号至 10922 号插槽。

  节点 C 负责处理 10923 号至 16383 号插槽。

 

在集群中录入值

  在redis-cli每次录入、查询键值,redis都会计算出该key应该送往的插槽,如果不是该客户端对应服务器的插槽,redis会报错,并告知应前往的redis实例地址和端口。

  redis-cli客户端提供了 c 参数实现自动重定向。

  如 redis-cli  -c p 6379 登入后,再录入、查询键值对可以自动重定向。

  不在一个slot下的键值,是不能使用mget,mset等多键操作

 

  可以通过{}来定义组的概念,从而使key{}内相同内容的键值对放到一个slot中去。

 

 

查询集群中的值

CLUSTER GETKEYSINSLOT <slot><count> 返回 count 个 slot 槽中的键。

 

 

 

故障恢复

  如果主节点下线?从节点能否自动升为主节点?  注意:15秒超时

  主节点恢复后,主从关系会如何?  主节点回来变成从机。

  如果所有某一段插槽的主从节点都宕掉,redis服务是否还能继续?

  如果某一段插槽的主从都挂掉,而cluster-require-full-coverage yes ,那么 ,整个集群都挂掉

  如果某一段插槽的主从都挂掉,而cluster-require-full-coverage no ,那么,该插槽数据全都不能使用,也无法存储。

  redis.conf中的参数  cluster-require-full-coverage

 

 

集群的Jedis开发

  即使连接的不是主机,集群会自动切换主机存储。主机写,从机读。

  无中心化主从集群。无论从哪台主机写的数据,其他主机上都能读到数据。

public class JedisClusterTest {
  public static void main(String[] args) { 
     Set<HostAndPort>set =new HashSet<HostAndPort>();
     set.add(new HostAndPort("192.168.31.211",6379));
     JedisCluster jedisCluster=new JedisCluster(set);
     jedisCluster.set("k1", "v1");
     System.out.println(jedisCluster.get("k1"));
  }
}

 

Redis 集群提供了以下好处与不足

  好处:1、实现扩容  2、分摊压力  3、无中心配置相对简单

  不足:1、多键操作是不被支持的  2、多键的Redis事务是不被支持的。lua脚本不被支持  3、由于集群方案出现较晚,很多公司已经采用了其他的集群方案,而代理或者客户端分片的方案想要迁移redis cluster,需要整体迁移而不是逐步过渡,复杂度较大。

 

 

 

 

posted @ 2022-09-09 09:21  Homnay  阅读(25)  评论(0)    收藏  举报