试验环境:
- centos7.6x64位,CentOS-7-x86_64-Minimal-1810.iso
百度网盘下载地址:https://pan.baidu.com/s/1ckjQS_DGuI-7GGvmvhLNKQ 提取码: 6gfc
linux的安装参照:centos7.6最小化安装 - redis-5.0.5.tar.gz
官网下载地址:http://download.redis.io/releases/redis-5.0.5.tar.gz
百度网盘下载地址:https://pan.baidu.com/s/1ipnB043h5Tvk7cYGKxSr8g 提取码: bdkh
参照:
- linux上运行多个redis实例参考:https://blog.youkuaiyun.com/u010476739/article/details/99686952
- 一主多从概念参照:https://www.cnblogs.com/leeSmall/p/8398401.html
一、试验一:简单的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上可以获取的到,也验证了配置额只读属性的从节点是不允许写入操作的。
拓展:这种结构优点是:
- 进行了读写分离,提高了数据访问的性能
- 持久化数据的操作可以放在从redis上
那么这种结构的缺点是:
- 如果主节点出现故障,需要人为处理(将任意一个从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同步数据的压力。