当前位置: 当前位置:首页 >数据库 >Redis集群的三种方式(二)! 正文

Redis集群的三种方式(二)!

2025-11-04 19:23:35 来源:多维IT资讯作者:数据库 点击:639次

  由于文章篇幅过长,种方特将内容分两篇文章发布,种方本篇文章接上一篇:【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 16371

  Cluster模式部署

  | 实验环境说明

  在生产环境中,如果部署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,如果超时了还没有输入,则会自动退出,b2b供应网需要再次创建!

  看到以下信息说明创建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的三种集群,你学会了吗?

作者:人工智能
------分隔线----------------------------
头条新闻
图片新闻
新闻排行榜