redis入门(6):redis实现一主多从

试验环境:

参照:

一、试验一:简单的1主2从

1. 架构图:
在这里插入图片描述
2. 在/usr/local/redis/bin目录下新建三个配置文件:redis-6500.conf、redis-6501.conf、redis-6502.conf

redis-6500.conf:

port 6500
daemonize yes
pidfile /var/run/redis_6500.pid
logfile "/usr/local/redis/bin/redis-6500.log"
dbfilename dump-6500.rdb

redis-6501.conf:

port 6501
daemonize yes
pidfile /var/run/redis_6501.pid
logfile "/usr/local/redis/bin/redis-6501.log"
dbfilename dump-6501.rdb
slaveof 127.0.0.1 6500
slave-read-only yes

redis-6502.conf:

port 6502
daemonize yes
pidfile /var/run/redis_6502.pid
logfile "/usr/local/redis/bin/redis-6502.log"
dbfilename dump-6502.rdb
slaveof 127.0.0.1 6500
slave-read-only yes

上面配置解释:

  • 上面三个配置文件都修改了的内容是redis监听的端口、以后台模式运行、pid文件写入位置、日志文件位置、持久化数据库文件
  • 其中从节点有个slave-read-only yes,这个配置是设置从redis只能读取数据,不能写入数据(避免数据不一致)
    此时目录/usr/local/redis/bin目录应为:
    在这里插入图片描述
    解释:
    在上面的配置中将6500端口配置为主redis、6501配置为从节点、6502配置为从节点(其实主节点不用配置,只配置从节点即可)
    3. 先启动主redis,再分别启动两个从redis
    命令操作如下图:
    在这里插入图片描述
    4. 查看主redis的状态
    执行:./redis-cli -p 6500 info replication
    如下图:
    在这里插入图片描述

可以看到,redis的主从节点信息都被列了出来

5. 查看其中一个从redis信息
执行:./redis-cli -p 6501 info replication
如下图:
在这里插入图片描述

可以看到,这里记录了主redis和从redis的大概信息

6. 测试:在主redis上保存数据,并在从redis上读取
执行命令如下图:
在这里插入图片描述

上图验证了,在主redis上存储的数据,在从redis上可以获取的到,也验证了配置额只读属性的从节点是不允许写入操作的。
拓展:这种结构优点是:

  1. 进行了读写分离,提高了数据访问的性能
  2. 持久化数据的操作可以放在从redis上

那么这种结构的缺点是:

  1. 如果主节点出现故障,需要人为处理(将任意一个从redis作为主redis)

二、试验二:复杂 的1主2从

结构图:
在这里插入图片描述
2.2 在上个试验的基础上,修改redis-6502.conf文件的配置
redis-6502.conf:将主redis从6500切换到6501

port 6502
daemonize yes
pidfile /var/run/redis_6502.pid
logfile "/usr/local/redis/bin/redis-6502.log"
dbfilename dump-6502.rdb
slaveof 127.0.0.1 6501
slave-read-only yes

2.3 以次启动redis-6500.conf redis-6501.conf redis-6502.conf
在这里插入图片描述
2.4 查看各个redis的状态
redis-6500.conf:
在这里插入图片描述
redis-6501.conf:在这里插入图片描述
redis-6502.conf:
在这里插入图片描述
2.5 测试:在主redis上保存数据,在从redis上获取数据
在这里插入图片描述

由此可以看到,主redis上存储的数据被保存到了另外两个redis上,这中架构的优点是缓解了主redis同步数据的压力。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jackletter

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值