广告
返回顶部
首页 > 资讯 > 数据库 >redis 主从复制
  • 203
分享到

redis 主从复制

redis主从复制 2017-04-16 19:04:30 203人浏览 无得
摘要

Redis 主从复制 master 节点提供数据,也就是写。slave 节点负责读。 不是说master 分支不能读数据,也能只是我们希望将读写进行分离。 slave 是不能写数据的,只能处理读请求 主从实现 客户端 127.0

redis 主从复制

Redis 主从复制

master 节点提供数据,也就是写。slave 节点负责读。

不是说master 分支不能读数据,也能只是我们希望将读写进行分离。

slave 是不能写数据的,只能处理读请求

主从实现

客户端 127.0.0.1:6379 服务器 212.64.89.173:6379

方式一

客户端发送请求同步命令

slaveof masterip masterport

slaveof 212.64.89.173 6379

方式二

客户端启动服务器参数

redis-server --slaveof masterip masterport

redis-server --slaveof 212.64.89.173 6379

方式三

在客户端的配置文件中写入 slaveof 信息

redis.conf

slaveof 212.64.89.173 6379

注意 断开主从链接方式: 客户端执行 slaveof no one

设置链接密码

server 端

服务启动后设置

config set requierpass 

配置文件添加密码

# redis.conf
requirepass 

client 端

命令设置密码

auth 

配置文件设置密码

masterauth 

启动客户端设置密码

redis-cli -a 

建立连接

建立链接的过程就是希望 master slave 都保有对方的 IPPort

数据同步

数据的同步分两部分,全量同步和增量同步,在增量同步结束后,master 应当保存Slave 同步数据的位置。

复制(积压)缓冲区

它有两部分组成 偏移量 + 字节值

结构

创建

1 当启动AOF 时就会创建 复制积压缓冲区

2 当被选为 master 节点,必须创建积压缓冲区

作用

保存所有的对数据修改或数据库修改的指令,查询指令不会被记录。

数据源

所有的进入master 的对数据修改或数据库修改的指令都会被填充到积压缓冲区中。

偏移量

1 MasterSlave 都会记录 offset 值, 每次复制都会对比offset 是否一致。如果一致,Master直接从 offset 处开始传缓冲区数据,如果不一致,那么Master将遵循 Slaveoffset 来传。当然会保证命令是完整的。

2 Master 保存有多个 offsetSlave 仅保存自己的。

3 Master发送一次,记录一次, Slave 接受一次记录一次。

关于Master注意

1如果master 数据量过大,应该避免业务高峰期进行数据同步。避免造成 master 阻塞

2 数据缓冲区满, 此时将会丢弃最早的记录(FIFO),如果全量复制的时间开销过大,则可能在开增量复制时候已经存在数据丢失,这会导致Master 和 Slave 数据不一致,为了保证一致性,必须开始新一轮的全量复制,完成后缓冲区又被填满并存在丢弃,则会让Slave进入死循环。

因此数据缓冲区要设置的大小合适(依具体情况而定)。

repl-backlog-size 1mb   # 默认的大小为 1MB

3 master 单机内存不应该占用主机内存过多。一般的 50 ~ 70% 预留下 30% ~ 50%来进行bgsave创建复制缓冲区、执行其他业务等。

关于Slave注意

1 为避免slave进行全量复制、部分复制时服务器响应阻塞或数据不同步,建议关闭此期间的对外服务。

slave-server-stale-data yes|no

2 数据同步阶段,master 发送给 slave 信息可以理解 master slave 的一个客户端,主动向slave发送命令。

3 多个slave同时对master请求数据同步,master发送的RDB文件增多,会对带宽造成巨大冲击,如果master宽带不足,因此数据同步需要根据业务需求,适量错峰。

4 slave过多时,应该对拓扑结构进行调整,由一主多从结构变为树状结构,中间结点即是master,也是slave。但是使用树状结构时,因为层级越深,数据同步时延越大,因此将强一致性的数据放在顶层节点,一致性稍弱的数据放在靠底层的节点。

命令传播

master数据库状态被修改后,导致主从服务器数据库状态不一致,此时需要让主从数据同步到一致的状态,同步的动作成为命令传播
master将接受到的数据变更命令发送给slaveslave接受命令后执行命令。

网络闪断闪连 忽略
短时间网络中断 部分复制
长时间网络中断 全量复制

服务器运行ID(runid)

每台服务器每次运行都会产生的身份识别码,同一个服务器多次运行产生的runid是不一样的。

形式:runid 由 40 个字符组成 一般是16进制的字符串

info server
run_id:409b6e9ea2e5c32958de8f365711598c98489f13

心跳机制

master

指令 PING

周期 repl-ping-slave-period 默认是 10s

作用 判断 slave 是否在线

查询 INFO replication 获取最后一次 slave 连接时间间隔 lag = 0 / 1 属于正常

slave

指令 REPLCONF{offset}

周期: 1s

作用1: 汇报自己的复制偏移量 获取最新的数据变更指令

作用2: 判断 master 是否存活

心跳注意事项

当 salve多数掉线 或者网络延时过高时,master 会拒绝所有的同步信息。

min-slaves-to-write 2   # 最小的 slave 数量

min-slaves-max-lag 8  # 最长的

当 slave 的数量小于2 ,或者所有的时延都大于等于 8 时,会强 关闭 master 的血功能来停止数据同步。

Slave 的数量和延时由REPLCONF{offset} 命令确认。

完整的主从复制流程

读写分离

在redis主从架构中,Master节点负责处理写请求,Slave节点只处理读请求。对于写请求少,读请求多的场景,例如电商详情页,通过这种读写分离的操作可以大幅提高并发量,通过增加redis从节点的数量可以使得redis的QPS达到10W+。

负载均衡

基于主从结构,配合读写分离,由slave分担master负载,并根据需求的变化,改变slave的数量,通过多个从节点分担数据读取负载,大大提高Redis服务器并发量与数据吞吐量

故障恢复

当master出现问题时,由slave提供服务,实现快速的故障恢复

数据冗余

实现数据热备份,时持久化之外的一种数据冗余方式

高可用基石

基于主从复制,构建哨兵模式与集群,实现redis 的高可用方案。

您可能感兴趣的文档:

--结束END--

本文标题: redis 主从复制

本文链接: https://www.lsjlt.com/news/6649.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis主从复制
    Redis支持简单易用的主从复制(master-slave replication)功能,该功能可以让从服务器成为主服务器的即使备份服务器。 作用: 主从备份,防止服务器宕机; 读写分离,分担主服务器的任务; 任务分离,从服务器分别担任备...
    99+
    2017-12-16
    Redis主从复制
  • redis 主从复制
    redis 主从复制 master 节点提供数据,也就是写。slave 节点负责读。 不是说master 分支不能读数据,也能只是我们希望将读写进行分离。 slave 是不能写数据的,只能处理读请求 主从实现 客户端 127.0...
    99+
    2017-04-16
    redis 主从复制
  • 浅谈Redis主从复制以及主从复制原理
    目录面临问题解决办法主从复制主从复制的作用主从复制启用面临问题 1. 机器故障。我们部署到一台 Redis 服务器,当发生机器故障时,需要迁移到另外一台服务器并且要保证数据是同步的。...
    99+
    2022-11-12
  • NoSQL之redis(主从复制)
    1.redis主从复制的介绍:     持久化保证了即使redis服务器重启也不会丢失数据,因为redis服务器重启后将硬盘上持久化的数据恢复到内存中, 但是当redis服务器的硬盘损坏了可能会导致数据丢失...
    99+
    2022-10-18
  • redis之master.slave主从复制
    简介 主机数据更新后根据配置和策略,自动同步到备机的master/slave机制,master以写为主,slave以读为主 从库配置 配置从库,不配主库 配置从库: 格式: slaveof 主库ip 主库port ...
    99+
    2020-12-18
    redis之master.slave主从复制
  • Redis--主从复制原理
    前言: 和MySQL主从复制的原因一样,Redis虽然读取写入的速度都特别快,但是也会产生读压力特别大的情况。为了分担读压力,Redis支持主从复制,Redis的主从结构可以采用一主多从或者级联结构,Red...
    99+
    2022-10-18
  • Redis主从复制详解
    单机Redis存在的问题 无法故障转移 ,无法避免单点故障 磁盘空间的瓶颈 QPS瓶颈 Redis主从复制的作用 提供数据副本 扩展读性能 配置方法 通过命令 通过配置文件 演示 为方便演示,在一台服务器上...
    99+
    2022-10-18
  • Redis系列(四):Redis的复制机制(主从复制)
    Redis的复制机制(主从复制)。 本篇博客是Redis系列的第4篇,主要讲解下Redis的主从复制机制。 本系列的前3篇可以点击以下链接查看: Redis系列(一):Redis简介及环境安装 Redi...
    99+
    2016-01-02
    Redis系列(四):Redis的复制机制(主从复制)
  • redis主从复制什么时候复制
    Redis的主从复制机制是指可以让从服务器(slave)能精确复制主服务器(master)的数据,如下图所示: (推荐学习:Redis视频教程) 上面的图表示的是一台master服务器与slave服务器的情况,其实一台master...
    99+
    2020-08-31
    redis
  • redis主从复制是什么
    Redis主从复制是一种数据同步机制,其中一个Redis实例(称为主节点)将其数据异步复制到其他一个或多个Redis实例(称为从节点...
    99+
    2023-09-09
    redis
  • Redis 主从复制全剖析
    Redis的主从复制是如何工作的?如何在同步数据的同时,还保持着高性能,你了解吗? https://redis.io/topics/replication 注意以下基于 redis 5 最新版本,slave 名词和配置项已经...
    99+
    2019-12-28
    Redis 主从复制全剖析
  • 图解Redis,Redis主从复制与Redis哨兵机制
    目录 专栏导读一、Redis复制是什么?二、Redis复制能干嘛?三、Redis复制的缺点1、复制延迟2、master宕机 四、乐观复制策略五、Redis复制常用命令1、info re...
    99+
    2023-09-06
    redis java 数据库 分布式
  • Redis主从复制流程概述
    Redis包含master和slave两种节点:master节点对外提供读写服务,slave节点作为master的数据备份,从主节点全量同步数据,主从复制架构下,默认Slave是只读的,如果写入则会报错,...
    99+
    2022-10-18
  • 怎么实现Redis主从复制
    本篇内容介绍了“怎么实现Redis主从复制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!架构主 192.1...
    99+
    2022-10-18
  • Redis主从复制失败(master_link_status down)
    今天在使用命令slaveof或者是replicaof命令配置redis主从复制时,从机出现master_link_status:down提示,显示主机是down的状态,主机显示没有从机挂载。 主要是因为这里的redis配置了密码,...
    99+
    2022-04-04
    Redis主从复制失败(master_link_status down)
  • Redis主从复制怎么使用
    这篇文章主要介绍“Redis主从复制怎么使用”,在日常操作中,相信很多人在Redis主从复制怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis主从复制怎么使用”...
    99+
    2022-10-19
  • 详解Redis主从复制实践
    目录复制简介服务介绍实现方式1. 服务启动时配置2. 命令行配置3. 配置文件配置4.配置说明效果测试1.主服务器添加数据2.从服务器获取数据实现原理实现策略1.全量复制2.部分复制...
    99+
    2022-11-12
  • redis主从复制之全量复制与部分复制
    一、什么事全量复制与部分复制? 全量复制:一般用于初次复制场景,Redis早期支持的复制功能只有全量复制,它会把主节点全部数据一次性发送给从节点,当数据量较大时,会对主从节点和网络造成很大的开销. 部分复...
    99+
    2022-10-18
  • Redis的主从复制是什么,主从复制的原理又是什么?
    redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有...
    99+
    2022-10-18
  • 如何使用Redis的主从复制?
    与mysql一样,redis也支持主从复制、读写分离,且配置比mysql要简单很多。下面我们来一起看看redis的主从复制。建立复制默认情况下,Redis都是主节点。现在,我来演示下如何开启主从复制。首先,...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作