Redis分布式集群搭建

1.配置文件

port 6379
#开启集群功能
cluster-enabled yes
#集群配置文件,redis自己维护确保唯一,最好绝对路径
cluster-config-file nodes.conf
#节点心跳失败的超时时间
cluster-node-timeout 15000
#持久化文件存放位置,最好绝对路径
dir /data
#指定访问的地址(任何人都可以访问)
bind 0.0.0.0
#是否后台运行
daemonize yes
#注册的实列ip
# replica-announce-ip 5.5.5.5
#保护模式
#protected-mode no
#数据库的使用数量 spring.redis.database=2
databases 4
#设置自己的密码
requirepass 123
#日志文件,最好绝对路径
logfile /run.log

2.只能启动一个实列的原因

  • 集群中不能开启主从备份,若开启需要将replicaof 这一行注释掉
  • 配置文件中的pidfile,需要确保唯一性
  • cluster-config-file配置,系统自动维护的配置文件需要确保唯一性,否则会使用同一个配置文件
  • 修改bind 0.0.0.0,任何地址都可访问

3.redis创建集群

redis5.0需要ruby环境。

redis5.0以后(推荐):

  • redis-cli --cluster create --cluster-replicas 1 192.168.0.1 192.168.0.2
  • redis-cli --cluster或者./redis-trib.rb :集群操作命令
  • create:代表创建集群
  • --cluster-replicas 1 或者--replicas 1:指定集群中每个master的副本个数为1,
  • 此时节点总数/(replicas +1)得到master的数量,所以节点前n个就是master,后面的其他节点都是slave节点,随机分配到不同的master。

4.报错

  • Waiting for the cluster to join
  • 解决方案:放你redis实例端口号+10000的端口
  • [ERR] Not all 16384 slots are covered by nodes.
  •  解决方案:用redis-cli 登录到每个节点执行   cluster reset  就可以了。
  • Node xxxx is not empty
  • 解决方案:用redis-cli 登录到每个节点执行   flushdb  就可以了。

你可能感兴趣的:(后端,redis,分布式,数据库)