Redis4 配置集群

应用场景

当主备复制场景,无法满足主机的单点故障时,需要引入集群配置。

一般数据库要处理的读请求远大于写请求 ,针对这种情况,我们优化数据库可以采用读写分离的策略。我们可以部 署一台主服务器主要用来处理写请求,部署多台从服务器 ,处理读请求。

 基本原理

哨兵选举机制,如果有半数节点发现某个异常节点,共同决定改异常节点的状态,如果该节点是主节点,对应的备节点自动顶替为主节点。Sentinel(哨兵)是Redis 的高可用性解决方案:由一个或多个Sentinel 实例 组成的Sentinel 系统可以监视任意多个主服务器,以及这些主服务器属下的所有从服务器,并在被监视的主服务器进入下线状态时,自动将下线主服务器属下的某个从服务器升级为新的主服务器。

主从复制的作用

1、数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式。

2、故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复;实际上是一种服务的冗余。

3、负载均衡:在主从复制的基础上,配合读写分离,可以由主节点提供写服务,由从节点提供读服务(即写Redis数据时应用连接主节点,读Redis数据时应用连接从节点),分担服务器负载;尤其是在写少读多的场景下,通过多个从节点分担读负载,可以大大提高Redis服务器的并发量。

4、读写分离:可以用于实现读写分离,主库写、从库读,读写分离不仅可以提高服务器的负载能力,同时可根据需求的变化,改变从库的数量。

5、高可用基石:除了上述作用以外,主从复制还是哨兵和集群能够实施的基础,因此说主从复制是Redis高可用的基础

配置集群所需的环境

Redis集群至少需要3个节点,因为投票容错机制要求超过半数节点认为某个节点挂了该节点才是挂了,所以2个节点无法构成集群。

要保证集群的高可用,需要每个节点都有从节点,也就是备份节点,所以Redis集群至少需要6台服务器。因为我没有那么多服务器,也启动不了那么多虚拟机,所在这里搭建的是伪分布式集群,即一台服务器虚拟运行6个redis实例,修改端口号为(7001-7006),当然实际生产环境的Redis集群搭建和这里是一样的。

1.规划网络

用一台虚拟机模拟6个节点,一台机器6个节点,创建出3 master、3 salve 环境。虚拟机是 CentOS7 ,ip地址

2.创建 Redis 节点

先建目录redis-cluster

3. 创建目录

4.配置redis7001.conf

include /usr/redis/bin/redis.conf

port 7006

dbfilename "dump_7006.rdb"

appendfilename "appendonly_7006.aof"

pidfile "/var/run/redis_7006.pid"

daemonize yes

logfile "/usr/redis/redis_cluster/7006/redis_err_7006.log"

bind 0.0.0.0

save 60 1

dir "/usr/redis/redis_cluster/7006"

appendonly yes

appendfsync always

protected-mode no

cluster-enabled yes

# 在不同的服务器 这个可以不要

cluster-config-file nodes-7006.conf

cluster-node-timeout 15000

5.将 redis.conf 拷贝到这六个目录中

echo ./7002 ./7003 ./7004 ./7005 ./7006 | xargs -n 1 cp -v /usr/java/redis_cluster/7001/redis.conf

6.启动这6个redis

/usr/redis/bin/redis-server  /usr/redis/redis_cluster/7001/redis.conf 

查看开启状况

7.创建redis的集群

./redis-cli --cluster create 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006  --cluster-replicas 1

配置成功

8.使用cli连接redis集群

/redis-cli -c -h (IP地址) -p 7002

查看集群的节点的信息 :cluster nodes

9.检查集群的状态

redis-cli --cluster check (IP地址):7001

10.添加主节点

在添加之前首先要像7001-6一样,修改配置文件,启动7007 服务

/redis-cli --cluster add-node (新的IP地址节点)7007 (集群内IP地址):7002

前面的IP加端口号是要添加的redis节点,后面的IP和端口号是集群中的任意一个节点。

检查节点的状态

给主节点分配slots  主节点slots默认0

11.配置从节点 

配置文件 7008 /redis.conf

启动

在添加之前首先要像7007一样,修改配置文件,启动7008 服务

添加从节点7008

刚才添加的主节点还没有分配槽,所以无法使用

添加从节点之前需要设置从节点并启动节点

--cluster-master-id 为从节点对应主节点的id

redis-cli --cluster add-node (新IP地址节点):7008 (现有集群的节点):7002 --cluster-slave --cluster-master-id (主节点id)

从节点 里面不存数据  所以不需要slots

删除节点
删除从节点

--cluster del-node 集群 节点id

删除主节点

--cluster del-node 集群 节点id

删除主节点需要先使用 reshard 把主节点的slots移到其他节点才可以

重新分配槽slots

slots移除完成

完成删除主节点

集群关闭

集群关闭的时候千万不要kill  如果kill 集群里面的信息会被破坏

配置一键启动集群

创建文件

编辑文件

启动

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值