Redis主从复制

本文详细介绍了Redis主从复制的配置步骤,包括一主两从的搭建过程,以及如何通过配置文件调整主服务器和从服务器的角色。通过具体实例展示了如何在主服务器上设置变量,并验证了从服务器能够正确地获取并显示这些变量,但不具备写入权限,确保了数据一致性。

相关概念请参考 : <<Redis设计与实现>>第15章 复制

  1. 同步、命令传播
  2. 部分重同步、完全重同步
  3. 旧版复制功能的缺陷:断开重连后总是执行完全重同步
  4. 部分重同步的实现:主从服务器的复制偏移量、主服务器复制挤压缓冲区、服务器的运行ID

重点:进行复制后,从服务器和主服务器具有相同的数据
  
主服务器master、从服务器slaver
  在Redis中,用户可以通过执行SLAVEOF命令或者设置slaveof选项,让一个服务器去复制另一个服务器,我们称呼被复制的服务器为主服务器(master),而对主服务器进行复制的服务器则被称为从服务器


一. 配置 << 一主两从 >>

step1. 配置
(1) 配置redis_master.conf

port 6379
pidfile /var/run/redis_6379.pid
# replicaof <masterip> <masterport>
logfile "/data/logs/redis.master.log"
daemonize yes

# save 900 1         # 关闭RDB,由slaver1替master分担
# save 300 10
# save 60 10000

appendonly yes  # 开启aof

(2) 复制配置redis_slaver1.conf

port 6380
pidfile /var/run/redis_6380.pid
slaveof 127.0.0.1 6379  # 作为6379的slaver
logfile "/data/logs/redis.slave1.log"
daemonize yes

dbfilename dump6380.rdb   # 6380开启RDB,master关闭RDB
appendonly no    # 关闭aof

(3) 复制配置redis_slaver2.conf

port 6381
pidfile /var/run/redis_6381.pid
slaveof 127.0.0.1 6379
logfile "/data/logs/redis.slave-6381.log"
daemonize yes

# save 900 1         # 关闭RDB
# save 300 10
# save 60 10000

dbfilename dump6381.rdb
appendonly no    # 关闭aof

step2. 开启服务器
杀死redis相关的程序:pkill -9 redis

./bin/redis-server redis_master.conf
./bin/redis-server redis_slaver1.conf -h 127.0.0.1 -p 6380
./bin/redis-server redis_slaver2.conf -h 127.0.0.1 -p 6381

step3. 查看服务器是否开启
在这里插入图片描述

二. 测试<< 一主两从 >>

  1. 使用客户端程序连接主服务器
./bin/redis-cli
./bin/redis-cli  -h 127.0.0.1 -p 6380
./bin/redis-cli  -h 127.0.0.1 -p 6381
  1. master中添加变量:
127.0.0.1:6379> set name Kobe
  1. slaver1/2中查看变量
    可以发现,在slaver中可以查看到master添加的变量name的值Kobe
127.0.0.1:6381> get name
"Kobe"
  1. slaver1/2不能修改name,因为为了保证数据的一致性,配置slaver只具有可读权限
127.0.0.1:6381> set name James
(error) READONLY You can't write against a read only replica. 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值