redis之主从复制

时间:2021-07-26 04:34:48

一、redis主从同步

redis之主从复制

原理:
1. 从服务器向主服务器发送 SYNC 命令。
2. 接到 SYNC 命令的主服务器会调用BGSAVE 命令,创建一个 RDB 文件,并使用缓冲区记录接下来执行的所有写命令。
3. 当主服务器执行完 BGSAVE 命令时,它会向从服务器发送 RDB 文件,而从服务器则会接收并载入这个文件。
4. 主服务器将缓冲区储存的所有写命令发送给从服务器执行。


-------------
1、在开启主从复制的时候,使用的是RDB方式的,同步主从数据的
2、同步开始之后,通过主库命令传播的方式,主动的复制方式实现
3、2.8以后实现PSYNC的机制,实现断线重连

1、环境准备

主库:6380的redis(master)
从库1:6381的redis(slave)
从库2:6382的redis(slave)

主库redis.conf配置

port 6380     # 端口
daemonize yes   # 在后台运行
pidfile /data/6380/redis.pid   # 进程id
loglevel notice
logfile "/data/6380/redis.log"   # 日志文件,需自己创建
dbfilename dump.rdb      # 持久化存储
dir /data/6380                
protected-mode no

从库1redis.conf配置

port 6381      
daemonize yes
pidfile /data/6381/redis.pid
loglevel notice
logfile "/data/6381/redis.log"
dbfilename dump.rdb
dir /data/6381
protected-mode no
slaveof   192.168.61.129  6380   # 指定主库的ip和端口

从库2redis.conf配置

port 6382
daemonize yes
pidfile /data/6382/redis.pid
loglevel notice
logfile "/data/6382/redis.log"
dbfilename dump.rdb
dir /data/6382
protected-mode no
slaveof   192.168.61.129  6380

注意:

如果主库中设置了密码,那么我们在从库的配置文件中就需要添加主库的密码

masterauth root   # 指定主库的密码

2、启动redis服务端

redis-server /data/6380/redis.conf 
redis-server /data/6381/redis.conf 
redis-server /data/6382/redis.conf 

3、登录数据库查看主从关系

主库【6380】:

[root@szx /data/6380 21:46:33]#redis-cli -p 6380 -h 192.168.61.129
192.168.61.129:6380> info  replication
# Replication
role:master
connected_slaves:2    # 有两个从库连接
slave0:ip=192.168.61.129,port=6381,state=online,offset=2100,lag=0
slave1:ip=192.168.61.129,port=6382,state=online,offset=2100,lag=0
master_replid:a70b4cc777e7f27efef1d2463f4d78d556a0162b
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:2100
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:2100

从库1【6381】:

[root@szx /data/6381 21:50:27]#redis-cli -p 6381 -h 192.168.61.129
192.168.61.129:6381> info  replication
# Replication
role:slave    # 从库
master_host:192.168.61.129  # 主库ip
master_port:6380      # 主库端口
master_link_status:up    # 连接主库正常
master_last_io_seconds_ago:4
master_sync_in_progress:0
slave_repl_offset:2226
slave_priority:100
slave_read_only:1
connected_slaves:0
master_replid:a70b4cc777e7f27efef1d2463f4d78d556a0162b
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:2226
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:2226

从库2【6382】:

[root@szx /data/6382 21:50:27]#redis-cli -p 6382 -h 192.168.61.129
127.0.0.1:6382> info replication
# Replication
role:slave
master_host:192.168.61.129
master_port:6380
master_link_status:up
master_last_io_seconds_ago:3
master_sync_in_progress:0
slave_repl_offset:2366
slave_priority:100
slave_read_only:1
connected_slaves:0
master_replid:a70b4cc777e7f27efef1d2463f4d78d556a0162b
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:2366
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:43
repl_backlog_histlen:2324

4、查看主从复制效果

主库写入数据

192.168.61.129:6380> SET name "alex"
OK
192.168.61.129:6380> mset name "wusir" age 88 
OK

从库1查看key

192.168.61.129:6381> get name 
"alex"
192.168.61.129:6381> mget name age 
1) "wusir"
2) "88"

从库2查看key

127.0.0.1:6382> get name 
"alex"
127.0.0.1:6382> mget name age 
1) "wusir"
2) "88"

二、主从复制故障恢复

从库挂了无所谓
主库挂了得立即恢复主库,或者将从库切换为主库,继续工作

    -.实验步骤
    1.分别启动 6380  6381 6382 三个数据库实例,建立好主从关系
    
    2.杀死6380主库,此时6381 6382 群龙无首
    
    3.选择让6381为新的主库,就要去除6381的从的身份
    redis-cli -p 6381 slaveof  no one 
    #查看此时6381的身份
    redis-cli -p 6381 info replication

    4.此时将6382的主人改为6381
    redis-cli -p 6382 slaveof 192.168.61.129 6381

这种故障恢复只是临时生效,重启服务器后就不生效了