主要内容
搭建redis集群
能力目标
搭建redis集群
一 应用场景
为什么需要redis集群?
当主备复制场景,无法满足主机的单点故障时,需要引入集群配置。
一般数据库要处理的读请求远大于写请求 ,针对这种情况,我们优化数据库可以采用读写分离的策略。我们可以部 署一台主服务器主要用来处理写请求,部署多台从服务器 ,处理读请求。
data:image/s3,"s3://crabby-images/8d614/8d614fefc5315821a78c0bfaf82074de74bb4f2d" alt=""
二 基本原理
哨兵选举机制,如果有半数节点发现某个异常节点,共同决定改异常节点的状态,如果该节点是主节点,对应的备节点自动顶替为主节点。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地址192.168.159.34
2,创建 Redis 节点
首先在 192.168.159.34 机器上 /usr/java/目录下创建 redis_cluster 目录;
mkdir redis_cluster
3 创建目录
在 redis_cluster 目录下,创建名为7001、7002,7003、7004、7005,7006的目录
mkdir 7001 7002 7003 7004 7005 7006
data:image/s3,"s3://crabby-images/9a840/9a84086216cd727aa327dd9f864026b0777d248a" alt=""
4 将 redis.conf 拷贝到这六个目录中,
echo ./7002 ./7003 ./7004 ./7005 ./7006 | xargs -n 1 cp -v /usr/java/redis_cluster/7001/redis.conf
data:image/s3,"s3://crabby-images/310e7/310e72391840f128c0b9734be700661e736a9aa0" alt=""
5 配置redis7001.conf
java
include /usr/java/redis_cluster/redis.conf
port 7001
pidfile "/var/run/redis_7001.pid"
dbfilename "dump_7001.rdb"
dir "/usr/java/redis_cluster/7001"
logfile "/usr/java/redis_cluster/7001/redis_err_7001.log"
cluster-enabled yes
cluster-config-file nodes-7001.conf
cluster-node-timeout 15000
后台启动
6 启动这6个redis
java
root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_cluster/7001/redis.conf
[root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_cluster/7002/redis.conf
[root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_cluster/7003/redis.conf
[root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_cluster/7004/redis.conf
[root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_cluster/7005/redis.conf
[root@localhost redis_cluster]# /usr/java/redis/bin/redis-server /usr/java/redis_
7 创建redis的集群
/usr/redis/bin/redis-cli --cluster create 192.168.159.34:7001 192.168.159.34:7002 192.168.159.34:7003 192.168.159.34:7004 192.168.159.34:7005 192.168.159.34:7006 --cluster-replicas 1
cluster-replicas 1
1其实代表的是一个比例,就是主节点数/从节点数的比例。那么想一想,在创建集群的时候,哪些节点是主节点呢?哪些节点是从节点呢?答案是将按照命令中IP:PORT的顺序,先是3个主节点,然后是3个从节点。
分配原则尽量保证每个主数据库运行在不同的IP地址,每个从库和主库不在一个IP地址上。
data:image/s3,"s3://crabby-images/f92b9/f92b9c665cefb8cd00147c1e4da09647c556b99c" alt=""
data:image/s3,"s3://crabby-images/59893/59893042706bc6fc480667294da36390edcfa6d0" alt=""
8 使用cli连接redis集群
使用客户端链接集群 必须使用 -c 连接
/usr/java/redis/bin/redis-cli -c -h 192.168.159.34 -p 7002
查看集群的节点的信息 :cluster nodes
data:image/s3,"s3://crabby-images/98e31/98e312b53c31afa6b7c6744d0b45ba98ebf22989" alt=""
data:image/s3,"s3://crabby-images/b3dc4/b3dc45561acd77f9efe49249b0956a439718cbbf" alt=""
9 检查集群的状态
/usr/java/redis/bin/redis-cli --cluster check 192.168.159.34:7002
data:image/s3,"s3://crabby-images/4c14c/4c14ce4c9afb8edfc22950a288b24ee3096fb839" alt=""
10 添加主节点
配置文件 7007 /redis.conf
启动
在添加之前首先要像7001-6一样,修改配置文件,启动7007 服务
/usr/java/redis/bin/redis-cli --cluster add-node 192.168.159.34:7007 192.168.159.34:7002
前面的IP加端口号是要添加的redis节点,后面的IP和端口号是集群中的任意一个节点。
检查节点的信息
data:image/s3,"s3://crabby-images/d40a9/d40a9da64ab9b1e380ae24854c4e67d49534b30d" alt=""
redis-cli --cluster add-node 新节点 集群中的节点
data:image/s3,"s3://crabby-images/8babf/8babf9b3f9030b64cd16775372e9a7b7dada2cca" alt=""
data:image/s3,"s3://crabby-images/596b0/596b080b5ab2d4892fc318262f8db973b427c785" alt=""
data:image/s3,"s3://crabby-images/4cbe2/4cbe28a95ec269dc29da939edc480ca7aaab580c" alt=""
data:image/s3,"s3://crabby-images/552bb/552bbbe9187cd936bf967d7fcaecc3b9dfc72180" alt=""
刚才添加的主节点还没有分配槽,所以无法使用
添加从节点之前需要设置从节点并启动节点
--cluster-master-id 为从节点对应主节点的id
/usr/java/redis/bin/redis-cli --cluster add-node 192.168.159.34:7008 192.168.159.34:7002 --cluster-slave --cluster-master-id 67211a02cffe48ee7197092ca48e9e7294dc5961
data:image/s3,"s3://crabby-images/9771f/9771f87eddba86305cf3ddfb5e4edb020b9174bc" alt=""
可以随意分配数量
data:image/s3,"s3://crabby-images/2e354/2e354374a316546e4e334d3c4816229a6a00d11b" alt=""
data:image/s3,"s3://crabby-images/33974/33974d47f726876075ab52f6c9b639c8e06ef814" alt=""
data:image/s3,"s3://crabby-images/3490e/3490ec0151219b39a80e3c1839b2c23e9fb3aef1" alt=""
data:image/s3,"s3://crabby-images/48bda/48bda2a0009e25c43408ff2e2753ae5cd4ff204f" alt=""
显示上图卡槽分配成功
批量添加
集群中进行批量添加
不允许
想添加
分组
{名字}
Mset k{u} 当设置了组名的时候分配槽的时候是根据组的名字分配的槽
data:image/s3,"s3://crabby-images/0d349/0d34935a2c17d2bbe2f28358d08a7938a83cc97f" alt=""
data:image/s3,"s3://crabby-images/c0840/c08404de3d0e3a62978f7e59178afdf81ea70d29" alt=""
删除从节点
data:image/s3,"s3://crabby-images/e5013/e50131b391f9a1a434320625117f7e10c195e79f" alt=""
删除主节点
data:image/s3,"s3://crabby-images/b896c/b896ccfcb011f3bbc75cf8710e4c4dae13bfaf62" alt=""
data:image/s3,"s3://crabby-images/0a4bd/0a4bd4ac614727be404a4e80b456e26bde76b070" alt=""
data:image/s3,"s3://crabby-images/1857f/1857f3151bf36a606c21cc66b6b8e9f8b0c6d61d" alt=""
测试集群
关闭7002
data:image/s3,"s3://crabby-images/27e99/27e99faedd8d1e4873ea8cb28e26908801d919a8" alt=""
data:image/s3,"s3://crabby-images/2e541/2e54123e0aa360375b864d54edb2abb736016c4b" alt=""
重启7002
data:image/s3,"s3://crabby-images/1bb89/1bb89afbc04e58a19c11eb7dea30bc75bf4d44ce" alt=""
重启之后变为从节点
data:image/s3,"s3://crabby-images/4e78b/4e78b24a2a8e9be73b27044a6f22433d6c198e50" alt=""