本文今天主要是Redis的主从复制功能,它是Redis提供的多机功能中最基础的一个,它允许用户为存储这目标数据库的服务器创建多个拥有相同数据库副本的服务器,目标数据库被称为主服务器(master server),副本服务器称为从服务器(slave server)。一个主服务器可以有多个从服务器,但是一个从服务器只能有一个主服务器,从服务器也可以是其他服务器的主服务器。常见的两个场景如下图:
那么主从复制有什么不同或者说有什么好处呢?我们先看下面这个对比图:
对于开启了复制功能的主从服务器,主服务在每次执行写操作之后,都会与所有从服务器进行数据同步,也就是将写操作反映到从服务器上。大致流程图如下:
在Redis5.0之前的版本,一直使用 SLAVEOF 作为复制命令,从5.0.0版本开始Redis正式将 SLAVEOF 命令改名为 REPLICAOF ,并且可能在未来的版本中 SLAVEOF 可能会被废弃。所以大家要根据自己的版本来看使用SLAVEOF还是 REPLICAOF ,反正5.0版本之后肯定是建议使用 REPLICAOF 。
REPLICAOF host port
比如我们有两台服务器,分配如下:
地址 | 端口 |
---|---|
127.0.0.1 | 6379 |
127.0.0.1 | 6380 |
我们想把 127.0.0.1:6379 当作主服务器, 127.0.0.1:6380 当作从服务器,首先我们在从服务 127.0.0.1:6380 上执行如下命令:
127.0.0.1:6380> REPLICAOF 127.0.0.1 6379
OK
接着我们去主服务器 127.0.0.1:6379 执行命令,设置一个键“name”,值为“alian”
127.0.0.1:6379> set name 'alian'
OK
127.0.0.1:6379> get name
"alian"
然后我们去从服务器 127.0.0.1:6380 应该是可以获取到键“name”的值的
127.0.0.1:6380> get name
"alian"
需要提醒的是,当我们的从服务器接收到 REPLICAOF 命令后,主从服务器将执行数据同步操作:从服务器原有的数据将被清空,取而代之的是从主服务器传送过来的数据副本,同步完成后,主从服务器拥有相同的数据。
我们除了使用 REPLICAOF 命令将运行中的Redis服务器设置为从服务器,还可以通过配置文件设置 REPLICAOF 选项,也就是在启动Redis服务器的同时将它设置为从服务器:
replicaof
我们还能在启动服务器时就设置为从服务器,比如启动命令如下:
redis-server --port 6380 --replicaof 127.0.0.1 6379
如果我们想让从服务器停止复制,重新变成主服务器则可以执行以下命令
replicaof no one
比如从服务 127.0.0.1:6380 取消复制
127.0.0.1:6380> replicaof no one
OK
服务器停止复制后不会清空数据库,而是会保留之前复制产生的数据,比如我们获取键“name”的值的
127.0.0.1:6380> get name
"alian"
127.0.0.1:6379> role
1) "master" # 表示主服务器
2) (integer) 1855 # 主服务器复制偏移量
3) 1) 1) "127.0.0.1" # 从服务器地址2) "6379" # 从服务器端口3) "1855" # 从服务器的复制偏移量
主服务器复制偏移量和从服务器的复制偏移量保持一致时,它们的数据就是一致的。
127.0.0.1:6380> role
1) "slave" # 表示从服务器
2) "127.0.0.1" # 主服务器地址
3) (integer) 6380 # 主服务器端口
4) "connected" # 主从服务器已经进入在线更新状态
5) (integer) 1953 # 从服务器复制偏移量
如果要使用无硬盘的复制特性,则设置如下:
repl-diskless-sync yes
为了降低数据不一致情况出现的概率,比如满足下面的条件才会执行写命令。
min-replicas-to-write 3 # 从服务至少有3个
min-replicas-max-lag 10 # 从服务器与主服务器最后一次通信的间隔不超过10
正常情况下从服务器默认只允许读命令,如果尝试写命令,就会报错,如果想打开从服务器的写功能,配置如下:
replica-read-only no
#注释掉下面这个绑定
# bind 127.0.0.1#关闭保护模式,就可以接收其他地址的连接请求
protected-mode no#端口自定义
port 6379
#进入redis目录
C:\Windows\System32>cd C:\myProgram\Redis-x64-5.0.14.1
#带配置启动redis服务
C:\myProgram\Redis-x64-5.0.14.1>redis-server.exe redis.windows.conf
#端口自定义
port 6380#配置复制功能
replicaof 192.168.0.100 6379
#进入redis目录
C:\Windows\System32>cd C:\Program Files\Redis-x64-5.0.14.1
#带配置启动redis服务
C:\Program Files\Redis-x64-5.0.14.1>redis-server.exe redis.windows.conf
主服务器上设置
127.0.0.1:6379> set num 100
OK
127.0.0.1:6379> set age 28
OK
从服务器上获取
#进入redis目录
C:\Windows\System32>cd C:\Program Files\Redis-x64-5.0.14.1
#启动redis客户端
C:\Program Files\Redis-x64-5.0.14.1>redis-cli.exe -h 127.0.0.1 -p 6380127.0.0.1:6380> keys *
1) "num"
2) "age"
127.0.0.1:6380> get num
"100"
127.0.0.1:6380> get age
"28"