Redis 主从复制

news2025/1/11 4:27:53

目录

    • 一、简介
    • 二、复制功能
    • 三、将服务器设置为从服务器
      • 3.1、手动设置
      • 3.2、REPLICAOF 配置选项
      • 3.3、取消复制
    • 四、查看服务器的角色
      • 4.1、查看主服务器
      • 4.2、查看从服务器
    • 五、其他配置
      • 5.1、无硬盘复制
      • 5.2、降低数据不一致情况出现的概率
      • 5.3、可写的从服务器
      • 5.4、选择性命令传播
    • 六、windows环境下主从配置
      • 6.1、主服务器
      • 6.2、从服务器
      • 6.3、主从复制结果

一、简介

  本文今天主要是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.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 命令后,主从服务器将执行数据同步操作:从服务器原有的数据将被清空,取而代之的是从主服务器传送过来的数据副本,同步完成后,主从服务器拥有相同的数据。

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.1:6380 取消复制

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"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/172361.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot统一功能处理

目录 一、统一用户的登录验证 1.1 Spring AOP 实现用户统一登录验证 1.2Spring拦截器实现统一用户的登录验证 1.3 实例演示&#xff08;通过url访问controller层的方法&#xff09; 二、统一异常处理 三、统一数据格式返回 3.1 统一数据返回格式的优点 3.2 统一数据返回…

旺季到来,跨境电商卖家年末冲刺!

又是一年年末时&#xff0c;随着新年的到来&#xff0c;在年底这段时间里&#xff0c;对于跨境电商卖家来说&#xff0c;又是一个关键节点。而现在&#xff0c;卖家们也将迎来一年一度的旺季收官&#xff0c;在此过程中卖家需要做好哪些准备做好年末冲刺呢&#xff1f; 在许多…

量化策略——准备3 数据、Backtrader回测框架与quantstats评价指标

我们一般使用AKShare这个库来获取股票数据或策略中用得到的数据&#xff1a; AKShare github主页&#xff1a;https://github.com/akfamily/akshare 使用Backtrader框架作为回测的框架&#xff1a; Backtrader github主页&#xff1a;https://github.com/mementum/backtrader …

【CTF】git源码泄露和代码审计

目录 源码获取 函数绕过 解法一&#xff1a; 解法二&#xff1a; 参考文章&#xff1a; 源码获取 这里做的web题目是buuctf中的&#xff1a;[GXYCTF2019]禁止套娃 打开页面&#xff0c;查看源码是没有可以利用的点的。开始进行目录扫描 这里使用的工具是dirsearch。直接…

前端js实现多次添加累加文件上传和选择删除(django+js)- 编辑回显文件并上传 (二)

前言 后端返回的是文件地址&#xff0c;并不是文件流或base64编码字符串&#xff0c;而修改数据的接口又只接受文件。 本篇文章主要是基于累加文件上传介绍的。 添加上传文件文章链接&#xff1a;https://blog.csdn.net/qq_43030934/article/details/128726549?spm1001.2014.…

jmeter 压测java代码

一、背景 直接压测、调用java工程中的方法。&#xff08;没有http等的入口&#xff09; 二、java项目改造 一个java项目&#xff0c;想要压测其中的几个方法。我们需要在该工程中&#xff0c;添加一个压测入口的类&#xff0c; 这个类必须继承或者实现jmeter提供的接口/类。…

C语言萌新如何使用scanf函数?

&#x1f40e;作者的话 如果你搜索输入输出函数&#xff0c;那么你会看到输入输出流、Turbo标准库、标准输出端、stdout什么什么乱七八糟的&#xff0c;作为一个萌新&#xff0c;哪懂这些&#xff1f; 本文介绍萌新在前期的学习中&#xff0c;常用的输入输出函数及其功能~ 跳…

HTML5+CSS3小实例:炫彩的发光字特效

前言&#xff1a; 今天我们向大家精选了一款HTML5CSS3文字特效&#xff0c;文字特效有超酷的动画类型&#xff0c;不多说&#xff0c;一起来看看。 描述&#xff1a; 这款文字特效既有倒影的效果&#xff0c;又有随机的颜色&#xff0c;看起来非常的炫酷。全文基于 HTML5CSS3 完…

log4j.properties自定义日志配置

一、通用的写法log4j.properties# 设置root logger等级为ALL&#xff0c;且appender有A1和FILE log4j.rootLoggerALL, A1,A3#设置com.example.test logger log4j.logger.com.example.testDEBUG,A1,A3 # 取消继承父类 log4j.additivity.com.example.testfalse# 设置个控制台输出…

即时通讯开发之TCP 连接的建立与中止

TCP 是一个面向连接的协议,所以在连接双方发送数据之前,都需要首先建立一条连接。这和前面讲到的协议完全不同。前面讲的所有协议都只是发送数据 而已,大多数都不关心发送的数据是不是送到,UDP 尤其明显,从编程的角度来说,UDP 编程也要简单 的多----UDP 都不用考虑数据分片。 书…

Ubuntu下源码编译VirtualBox一 —— 源码下载

VirtualBox想必大家都不陌生&#xff0c;做Linux开发的尤其是嵌入式Linux开发的人应该基本都知道或玩过VMware和VirtualBox。但通常都是为了在Windows电脑上能够使用Linux环境、即在Windows环境下通过下载可执行文件安装的VirtualBox。本文介绍在Linux环境&#xff08;Ubuntu 2…

系分 - 论文 - 总览知识点

个人总结&#xff0c;仅供参考&#xff0c;欢迎加好友一起讨论 文章目录系分 - 论文 - 总览往年论文一览论文考点考试时间考试过程论文技巧论文写作论文扣分与加分系分 - 论文 - 总览 往年论文一览 一般情况下&#xff0c;往下数5、6年的题目出题形式&#xff0c;具有参考意义…

痞子衡嵌入式:盘点国内Cortex-M内核MCU厂商高主频产品(2023)

大家好&#xff0c;我是痞子衡&#xff0c;是正经搞技术的痞子。今天痞子衡给大家介绍的是国内Cortex-M内核MCU厂商高主频产品。 在 2021 年初痞子衡写了篇 《盘点国内Cortex-M内核MCU厂商高性能产品》&#xff0c;搜罗了当时市面上主频不低于 96MHz 的 CM 核国产 MCU。如今过去…

LSTM MultiheadAttention 输入维度

最近遇到点问题&#xff0c;对于模块的输入矩阵的维度搞不清楚&#xff0c;这里在学习一下&#xff0c;记录下来&#xff0c;方便以后查阅。 LSTM & Attention 输入维度LSTM记忆单元门控机制LSTM结构LSTM的计算过程遗忘门输入门更新记忆单元输出门LSTM单元的pytorch实现Pyt…

Spring Security in Action 第七章 配置授权:限制访问

本专栏将从基础开始&#xff0c;循序渐进&#xff0c;以实战为线索&#xff0c;逐步深入SpringSecurity相关知识相关知识&#xff0c;打造完整的SpringSecurity学习步骤&#xff0c;提升工程化编码能力和思维能力&#xff0c;写出高质量代码。希望大家都能够从中有所收获&#…

[leetcode 72] 编辑距离

题目 题目&#xff1a;https://leetcode.cn/problems/edit-distance/description/ 类似题目&#xff1a;[leetcode 583] 两个字符串的删除操作 解法 动态规划 这题应该是字符串dp的终极形态了吧&#x1f923;&#xff0c;不看答案完全不会…看了答案发现原来还是dp… 以例题…

未来的竞争是认知和执行力的竞争,只有认知高,强执行才能赚钱

之前很火的一句话是&#xff1a;你永远赚不到认知范围之外的钱所以只有持续不断地提升认知才能持续成长&#xff0c;持续提升&#xff0c;持续赚钱。未来的竞争从另一方面来说也是认知的竞争。不同的认知对待同一事物、信息有不同的理解&#xff1b;不同的认知对待同一事物、信…

固高科技在创业板提交注册:业绩开始下滑,实控人均为“学院派”

近日&#xff0c;固高科技股份有限公司&#xff08;下称“固高科技”&#xff09;在深圳证券交易所创业板递交注册。据贝多财经了解&#xff0c;固高科技于2021年12月在创业板递交上市申请&#xff0c;2022年8月17日获得上市委会议通过。 本次冲刺创业板上市&#xff0c;固高科…

【一道面试题】说一下Synchronized?

说一下Synchronized&#xff1f; Synchronized锁是Java中为了解决线程安全问题的一种方式&#xff0c;是一种悲观锁Synchronized可以用来修饰方法或者以代码块&#xff0c;用来保证线程执行方法或代码块时的原子性Java中任何一个类的对象都可以用来作为锁对象&#xff0c;但是…

docker-15-镜像Ubuntu20.04中安装python3.9

1 拉取并运行镜像 从docker hub 拉取镜像&#xff0c;以ubuntu20.04为例&#xff1a; docker pull ubuntu:20.04 docker run -it ubuntu:20.04 /bin/bash发现命令行变为root1234abcd5678:&#xff0c;这样就是进入docker容器里了。以下是docker常用的命令&#xff1a; # 以…