由于文章篇幅过长,种方特将内容分两篇文章发布,种方本篇文章接上一篇:【LinuxSRE工程师培训】Redis集群的种方三种方式,你都掌握了吗?种方跟着小编继续学习吧。

哨兵模式部署
| 准备3个Redis实例
(可以直接基于上一节搭建的种方主从复制环境即可)

| 创建sentinel的配置文件,数据,种方日志存储目录
mkdir /oldboyedu/softwares/redis16379 cat > /oldboyedu/softwares/redis16379/sentinel.conf <<EOF bind 10.0.0.112 127.0.0.1 port 16379 dir /oldboyedu/data/redis16379 sentinel monitor oldboyedu_master 10.0.0.112 16370 1 sentinel down-after-milliseconds oldboyedu_master 5000 sentinel auth-pass oldboyedu_master oldboyedu EOF配置文件参数说明如下:

| 启动sentinel进程并查看日志
启动sentinel进程
redis-sentinel /oldboyedu/softwares/redis16379/sentinel.conf &> /oldboyedu/logs/redis16379/sentinel.log &查看日志信息
tail -100f /oldboyedu/logs/redis16379/sentinel.log
| 手动停止主库运行,种方模拟主库宕机
手动将主库宕机,种方观察从库被sentinel实现了自动切换
redis-cli -p 16370 -a oldboyedu SHUTDOWN # 由于我们将主库服务停了,种方因此无法再次连接主库了 redis-cli -p 16370 -a oldboyedu INFO REPLICATION redis-cli -p 16371 -a oldboyedu INFO REPLICATION
查看sentinel的种方日志信息,不难发现有记录切换的种方过程,如下所示
tail -100f /oldboyedu/logs/redis16379/sentinel.log
| 手动修复宕机的种方主库,sentinel会自动发现
修复之后,种方之前宕机的种方主库会自动加入集群并成为slaves节点
redis-server /oldboyedu/softwares/redis16370/redis.conf redis-cli -p 16370 -a oldboyedu INFO REPLICATION
温馨提示:除了提到上面的变化外,还有一点变化就是种方配置文件也修改了,每个"slave"节点都新增了以下两行:
(本案例只有"redis16370"和"redis16372"这两个实例的配置文件是slave节点,因此这两个节点中是存在的!)
# tail -3 /oldboyedu/softwares/redis16370/redis.conf # Generated by CONFIG REWRITE user default on #4208512d2963b999e0ef7a467cb42671c30be4d629ec75536a0eb6db15ee0d90 ~* &* +@all replicaof 10.0.0.112 16371 # tail -3 /oldboyedu/softwares/redis16372/redis.conf # Generated by CONFIG REWRITE user default on #4208512d2963b999e0ef7a467cb42671c30be4d629ec75536a0eb6db15ee0d90 ~* &* +@all replicaof 10.0.0.112 16371Cluster模式部署
| 实验环境说明
在生产环境中,如果部署6个redis实例,一般会放到3台硬件服务器
在企业规划中,网站模板一个分片被分配到两个不同的物理机,防止硬件主机宕机造成的整个分片数据丢失
温馨提示:
本案例为了实验方便,就直接将6个Redis实例放在同一个节点上,对应的端口号为:63790-63795
| 创建多Redis实例使用的配置文件,数据,日志目录
mkdir -pv /oldboyedu/softwares/redis1000{0..5} mkdir -pv /oldboyedu/data/redis1000{0..5} mkdir -pv /oldboyedu/logs/redis1000{0..5}| 为各个Redis实例创建配置文件
# 创建"redis10000"实例的配置文件 cat > /oldboyedu/softwares/redis10000/redis.conf <<EOF port 10000 daemonize yes pidfile /oldboyedu/data/redis10000/redis.pid loglevel notice logfile /oldboyedu/logs/redis10000/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10000 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF # 创建"redis10001"实例的配置文件 cat > /oldboyedu/softwares/redis10001/redis.conf <<EOF port 10001 daemonize yes pidfile /oldboyedu/data/redis10001/redis.pid loglevel notice logfile /oldboyedu/logs/redis10001/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10001 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF # 创建"redis10002"实例的配置文件 cat > /oldboyedu/softwares/redis10002/redis.conf <<EOF port 10002 daemonize yes pidfile /oldboyedu/data/redis10002/redis.pid loglevel notice logfile /oldboyedu/logs/redis10002/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10002 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF # 创建"redis10003"实例的配置文件 cat > /oldboyedu/softwares/redis10003/redis.conf <<EOF port 10003 daemonize yes pidfile /oldboyedu/data/redis10003/redis.pid loglevel notice logfile /oldboyedu/logs/redis10003/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10003 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF # 创建"redis10004"实例的配置文件 cat > /oldboyedu/softwares/redis10004/redis.conf <<EOF port 10004 daemonize yes pidfile /oldboyedu/data/redis10004/redis.pid loglevel notice logfile /oldboyedu/logs/redis10004/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10004 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF # 创建"redis10005"实例的配置文件 cat > /oldboyedu/softwares/redis10005/redis.conf <<EOF port 10005 daemonize yes pidfile /oldboyedu/data/redis10005/redis.pid loglevel notice logfile /oldboyedu/logs/redis10005/redis.log dbfilename dump.rdb dir /oldboyedu/data/redis10005 bind 10.0.0.112 127.0.0.1 # 配置RDB持久化策略 save 900 1 save 300 10 save 60 10000 # 配置AOF持久化 appendonly yes appendfsync everysec # 配置Redis Cluster模式 protected-mode no cluster-enabled yes cluster-config-file nodes.conf cluster-node-timeout 5000 EOF配置参数说明:

温馨提示:
1、Redis的端口号范围在10000~55535之间。这是因为当我们启动各个redis实例后,会监听在对应redis实例的端口上加10000;
2、由于上面我使用了"protected-mode no"指令,表示不开启安全模式,如果设置为"YES",尽管配置了"requirepass"和"masterauth"这两个配置项,我们在将redis节点加入到集群时依旧会报错哟!
3、Redis cluster模式无需像redis sentinel模式那样有一个专门的监控模式;
| 启动各个Redis实例
redis-server /oldboyedu/softwares/redis10000/redis.conf redis-server /oldboyedu/softwares/redis10001/redis.conf redis-server /oldboyedu/softwares/redis10002/redis.conf redis-server /oldboyedu/softwares/redis10003/redis.conf redis-server /oldboyedu/softwares/redis10004/redis.conf redis-server /oldboyedu/softwares/redis10005/redis.conf| 将节点加入集群管理
redis-cli --cluster create 10.0.0.112:10000 10.0.0.112:10001 10.0.0.112:10002 10.0.0.112:10003 10.0.0.112:10004 10.0.0.112:10005 --cluster-replicas 1注意:这里需要自己手动输入yes,如果超时了还没有输入,则会自动退出,免费信息发布网需要再次创建!
看到以下信息说明创建redis缓存库成功:

| 查看集群的状态
# 查看集群的状态 redis-cli -p 10005 CLUSTER NODES # 查看master节点的状态 redis-cli -p 10005 CLUSTER NODES | grep "master" # 查看slave节点的状态 redis-cli -p 10005 CLUSTER NODES | grep "slave"
每项的含义如下:

各flags的含义 (上面所说数据项3):

温馨提示:
1、如果有"myself"字样,说明你正在连接的是哪个节点;
2、注意观察槽位编号信息,比如"10.0.0.112:10000 master"被分配到的槽位号是"0-5460",而"10.0.0.112:10001"被分配到的槽位号是"5461-10922","10.0.0.112:10002 master"被分配到的槽位号是"10923-16383";
3、每个redis实例都有其独有的id编号,比如"10.0.0.112:10000 master"的编号为"eefe41adf0a9dc823ef56183881bfa14f10571b9",这有点类似于MySQL的"server_uuid";
总结:在本教程中,我们通过一些示例学习了如何去部署Redis的三种集群,你学会了吗?


相关文章
精彩导读
热门资讯
关注我们
