Redis 主从复制

一、简介

  本文今天主要是Redis的主从复制功能它是Redis提供的多机功能中最基础的一个它允许用户为存储这目标数据库的服务器创建多个拥有相同数据库副本的服务器目标数据库被称为主服务器master server副本服务器称为从服务器slave server。一个主服务器可以有多个从服务器但是一个从服务器只能有一个主服务器从服务器也可以是其他服务器的主服务器。常见的两个场景如下图

在这里插入图片描述

二、复制功能

  那么主从复制有什么不同或者说有什么好处呢我们先看下面这个对比图
在这里插入图片描述

  • 没有启用复制功能时读写操作都在主服务器上一个是服务器的压力大另外如果主服务器挂了风险极大
  • 启用了复制功能时主服务器依然可以进行读写操作从服务可以进行读操作这样可以分担主服务器的压力主服务器挂了也能提供部分服务但是复杂度提高了

  对于开启了复制功能的主从服务器主服务在每次执行写操作之后都会与所有从服务器进行数据同步也就是将写操作反映到从服务器上。大致流程图如下

在这里插入图片描述

三、将服务器设置为从服务器

3.1、手动设置

  在Redis5.0之前的版本一直使用 SLAVEOF 作为复制命令从5.0.0版本开始Redis正式将 SLAVEOF 命令改名为 REPLICAOF 并且可能在未来的版本中 SLAVEOF 可能会被废弃。所以大家要根据自己的版本来看使用SLAVEOF还是 REPLICAOF 反正5.0版本之后肯定是建议使用 REPLICAOF

REPLICAOF host port
  • host 指定主服务器的地址
  • port 指定主服务器的端口

比如我们有两台服务器分配如下

地址端口
127.0.0.16379
127.0.0.16380

  我们想把 127.0.0.16379 当作主服务器 127.0.0.16380 当作从服务器首先我们在从服务 127.0.0.16380 上执行如下命令

127.0.0.1:6380> REPLICAOF 127.0.0.1 6379
OK

接着我们去主服务器 127.0.0.16379 执行命令设置一个键“name”值为“alian”

127.0.0.1:6379> set name 'alian'
OK
127.0.0.1:6379> get name
"alian"

然后我们去从服务器 127.0.0.16380 应该是可以获取到键“name”的值的

127.0.0.1:6380> get name
"alian"

  需要提醒的是当我们的从服务器接收到 REPLICAOF 命令后主从服务器将执行数据同步操作从服务器原有的数据将被清空取而代之的是从主服务器传送过来的数据副本同步完成后主从服务器拥有相同的数据。

3.2、REPLICAOF 配置选项

  我们除了使用 REPLICAOF 命令将运行中的Redis服务器设置为从服务器还可以通过配置文件设置 REPLICAOF 选项也就是在启动Redis服务器的同时将它设置为从服务器

replicaof <masterip> <masterport>

  我们还能在启动服务器时就设置为从服务器比如启动命令如下

redis-server --port 6380 --replicaof 127.0.0.1 6379

3.3、取消复制

  如果我们想让从服务器停止复制重新变成主服务器则可以执行以下命令

replicaof no one

比如从服务 127.0.0.16380 取消复制

127.0.0.1:6380> replicaof no one
OK

  服务器停止复制后不会清空数据库而是会保留之前复制产生的数据比如我们获取键“name”的值的

127.0.0.1:6380> get name
"alian"

四、查看服务器的角色

4.1、查看主服务器

127.0.0.1:6379> role
1) "master"              # 表示主服务器
2) (integer) 1855        # 主服务器复制偏移量
3) 1) 1) "127.0.0.1"     # 从服务器地址
      2) "6379"          # 从服务器端口
      3) "1855"          # 从服务器的复制偏移量

  主服务器复制偏移量和从服务器的复制偏移量保持一致时它们的数据就是一致的。

4.2、查看从服务器

127.0.0.1:6380> role
1) "slave"       # 表示从服务器
2) "127.0.0.1"        # 主服务器地址
3) (integer) 6380     # 主服务器端口
4) "connected"        # 主从服务器已经进入在线更新状态
5) (integer) 1953     # 从服务器复制偏移量
  • none 主服务器尚未建立连接
  • connect 主从服务器正在握手
  • connecting 主从服务器建立了连接
  • sync 主从服务器正在进行数据同步
  • connected 主从服务器已经进入在线更新状态
  • unknown 主从服务器连接状态未知

五、其他配置

5.1、无硬盘复制

  如果要使用无硬盘的复制特性则设置如下

repl-diskless-sync yes

5.2、降低数据不一致情况出现的概率

  为了降低数据不一致情况出现的概率比如满足下面的条件才会执行写命令。

min-replicas-to-write 3    # 从服务至少有3个
min-replicas-max-lag 10    # 从服务器与主服务器最后一次通信的间隔不超过10

5.3、可写的从服务器

  正常情况下从服务器默认只允许读命令如果尝试写命令就会报错如果想打开从服务器的写功能配置如下

replica-read-only no

5.4、选择性命令传播

  • redis.REPL_ALL默认值将写命令传播至AOF文件以及所有从服务器
  • redis.REPL_AOF只将写命令传播至AOF文件
  • redis.REPL_SLAVE只将写命令传播至所有从服务器
  • redis.REPL_NONE不传播写命令

六、windows环境下主从配置

6.1、主服务器

  • 主服务器 192.168.0.100配置文件 redis.windows.conf 修改
#注释掉下面这个绑定
# bind 127.0.0.1

#关闭保护模式就可以接收其他地址的连接请求
protected-mode no

#端口自定义
port 6379
  • 主服务器启动时带配置文件不然你的配置不生效使用管理员身份启动 cmd.exe 进入到redis的目录然后执行
#进入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
  • windows主服务器的防火墙规则配置或者直接关闭

6.2、从服务器

  • 从服务器 192.168.0.200配置文件 redis.windows.conf 修改
#端口自定义
port 6380

#配置复制功能
replicaof 192.168.0.100 6379
  • 从服务器启动时带配置文件不然你的配置不生效使用管理员身份启动 C:\Windows\System32\cmd.exe 进入到redis的目录然后执行
#进入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

6.3、主从复制结果

主服务器上设置

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 6380

127.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"
阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: redis