搭建redis集群
能力目标
搭建redis集群
为什么需要redis集群?
当主备复制场景,无法满足主机的单点故障时,需要引入集群配置。
一般数据库要处理的读请求远大于写请求 ,针对这种情况,我们优化数据库可以采用读写分离的策略。我们可以部 署一台主服务器主要用来处理写请求,部署多台从服务器 ,处理读请求。
哨兵选举机制,如果有半数节点发现某个异常节点,共同决定改异常节点的状态,如果该节点是主节点,对应的备节点自动顶替为主节点。Sentinel(哨兵)是Redis 的高可用性解决方案:由一个或多个Sentinel 实例 组成的Sentinel 系统可以监视任意多个主服务器,以及这些主服务器属下的所有从服务器,并在被监视的主服务器进入下线状态时,自动将下线主服务器属下的某个从服务器升级为新的主服务器。
1、数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式。
2、故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复;实际上是一种服务的冗余。
3、负载均衡:在主从复制的基础上,配合读写分离,可以由主节点提供写服务,由从节点提供读服务(即写Redis数据时应用连接主节点,读Redis数据时应用连接从节点),分担服务器负载;尤其是在写少读多的场景下,通过多个从节点分担读负载,可以大大提高Redis服务器的并发量。
4、读写分离:可以用于实现读写分离,主库写、从库读,读写分离不仅可以提高服务器的负载能力,同时可根据需求的变化,改变从库的数量。
5、高可用基石:除了上述作用以外,主从复制还是哨兵和集群能够实施的基础,因此说主从复制是Redis高可用的基础
配置集群所需的环境
Redis集群至少需要3个节点,因为投票容错机制要求超过半数节点认为某个节点挂了该节点才是挂了,所以2个节点无法构成集群。
要保证集群的高可用,需要每个节点都有从节点,也就是备份节点,所以Redis集群至少需要6台服务器。因为我没有那么多服务器,也启动不了那么多虚拟机,所在这里搭建的是伪分布式集群,即一台服务器虚拟运行6个redis实例,修改端口号为(7001-7006),当然实际生产环境的Redis集群搭建和这里是一样的。
用一台虚拟机模拟6个节点,一台机器6个节点,创建出3 master、3 salve 环境。虚拟机是 CentOS7 ,ip地址192.168.244.34
首先在 192.168.244.34 机器上 /usr/myredis/目录下创建 文件夹;
mkdir 7001 7002 7003 7004 7005 7006
在 myredis 目录下,创建名为7001、7002,7003、7004、7005,7006的目录
mkdir 7001 7002 7003 7004 7005 7006
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
集群配置一般不要设置密码
后台启动
echo ./7002 ./7003 ./7004 ./7005 ./7006 | xargs -n 1 cp -v /usr/myredis/7001/redis.conf
修改里面的配置文件
把7001改成对应的
[root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7001/redis.conf [root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7002/redis.conf [root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7003/redis.conf [root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7004/redis.conf [root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7005/redis.conf [root@localhost myredis]# /usr/redis/bin/redis-server /usr/myredis/7006/redis.conf
查看状态 ps -ef|grep redis
一键启动redis
创建stredis.conf
把以下内容放到stredis.conf
直接用 vim stredis.conf创建
#!/bin/bash /usr/redis/bin/redis-server /usr/myredis/7001/redis.conf /usr/redis/bin/redis-server /usr/myredis/7002/redis.conf /usr/redis/bin/redis-server /usr/myredis/7003/redis.conf /usr/redis/bin/redis-server /usr/myredis/7004/redis.conf /usr/redis/bin/redis-server /usr/myredis/7005/redis.conf /usr/redis/bin/redis-server /usr/myredis/7006/redis.conf
启动
会提示权限不够
需要添加权限
然后就可以启动成功了
/usr/redis/bin/redis-cli --cluster create 192.168.244.34:7001 192.168.244.34:7002 192.168.244.34:7003 192.168.244.34:7004 192.168.244.34:7005 192.168.244.34:7006 --cluster-replicas 1
cluster-replicas 1
1其实代表的是一个比例,就是主节点数/从节点数的比例。那么想一想,在创建集群的时候,哪些节点是主节点呢?哪些节点是从节点呢?答案是将按照命令中IP:PORT的顺序,先是3个主节点,然后是3个从节点。
分配原则尽量保证每个主数据库运行在不同的IP地址,每个从库和主库不在一个IP地址上。
前三个为主 后三个为从
配置成功如下图
三个主共分0-16483个槽
配置的规则是否同意
出现这个,就是集群创建成功
使用客户端链接集群 必须使用 -c 连接
-c cluster (-c一定不能省略)
-h 主机ip
-p 端口号
/usr/java/redis/bin/redis-cli -c -h 192.168.244.34(可以省略不写) -p 7001
info replication
查看集群的节点的信息 :cluster nodes
/usr/redis/bin/redis-cli --cluster check 192.168.244.34:7001(这个任意写一个都可以)
配置文件 7007 /redis.conf
启动
在添加之前首先要像7001-6一样,修改配置文件,启动7007 服务
添加主节点
前面的IP加端口号是要添加的redis节点,后面的IP和端口号是集群中的任意一个节点。
/usr/redis/bin/redis-cli --cluster add-node 192.168.244.34:7007 192.168.244.34:7001
查看节点状态
给7008配置并修改
启动7008并查看状态
配置7008的端口号成为7007的从节点
先将节点接入到集群里面, 设置节点的状态 -cluster-slave --cluster-master=id
执行[root@localhost myredis]# /usr/redis/bin/redis-cli --cluster add-node 192.168.244.34:7008 192.168.244.34:7001 --cluster-slave --cluster-master-id a261b0ca5b4f4d225a18418f18456288e1dee6f8
出现下图就是成功了
添加的主节点还不能使用,因为没有分配slots,
重新分配slots
slot的概念。slot对于Redis集群而言,就是一个存放数据的地方,就是一个槽。对于每一个Master而言,会存在一个slot的范围,而Slave则没有。在Redis集群中,依然是Master可以读、写,而Slave只读
/usr/redis/bin/redis-cli --cluster reshard 192.168.244.34:7001
all 代表从所有有数据据节点进行迁移到目的节点,也可以选择 目标节点id回车,最后以done进行结束
done 代表结束
分配成功以后
分配了500个
删除节点
--cluster del-node 集群的节点 节点的id
节点id
/usr/redis/bin/redis-cli --cluster del-node 192.168.244.34:7001 0be93a31b9ec47184b23e5409b1df9482181bc5f
已经没有7008了
删除主节点需要先使用 reshard 把主节点的slots移到其他节点才可以
需要把槽归还回去
步骤跟要槽一样
这样就可以成功删除
验证集群是否生效:
关闭一个主节点查看对应的备用节点是不是能够顶替主节点成为主节点
存/取数据的时候查看对应的端口号
(关闭主节点以后需要耐心等待一会儿 让他重新分配一下空间)
关闭的时候一定要使用shutdown命令不要使用kill命令1.在集群中录入值
因为7002是主.7005是7002的从
现在7005自动是主
7002再次启动会俯首称臣
在redis-cli每次录入、查询键值,redis都会计算出该key应该送往的插槽,如果不是该客户端对应服务器的插槽,redis会报错,并告知应前往的redis实例地址和端口。
redis-cli客户端提供了 –c 参数实现自动重定向。
如 redis-cli -c –p 7000登入后,再录入、查询键值对可以自动重定向。
不在一个slot下的键值,是不能使用mget,mset等多键操作。
批量添加
集群中进行批量添加 不允许
想添加 必须分组(名字)
mget k{u}
可以通过{}来定义组的概念,从而使key中{}内相同内容的键值对放到一个slot中去。(按组分配插槽)
取值同样如此
一定要优雅的关闭
不能 kill -9
#!/bin/bash /usr/local/bin/redis-cli -h 192.168.184.33 -p 7001 shutdown /usr/local/bin/redis-cli -h 192.168.184.33 -p 7002 shutdown /usr/local/bin/redis-cli -h 192.168.184.33 -p 7003 shutdown /usr/local/bin/redis-cli -h 192.168.184.33 -p 7004 shutdown /usr/local/bin/redis-cli -h 192.168.184.33 -p 7005 shutdown /usr/local/bin/redis-cli -h 192.168.184.33 -p 7006 shutdown
配置权限