应用场景
当主备复制场景,无法满足主机的单点故障时,需要引入集群配置。
一般数据库要处理的读请求远大于写请求 ,针对这种情况,我们优化数据库可以采用读写分离的策略。我们可以部 署一台主服务器主要用来处理写请求,部署多台从服务器 ,处理读请求。
基本原理
哨兵选举机制,如果有半数节点发现某个异常节点,共同决定改异常节点的状态,如果该节点是主节点,对应的备节点自动顶替为主节点。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 集群里面的信息会被破坏
配置一键启动集群
创建文件
编辑文件
启动