一、目录

Redis复制的原理与优化

        什么是主从复制
全量复制和部分复制
复制的配置
故障处理
开发运维常见问题

二、 什么是主从复制

1、单机有什么问题?

单机如果机器故障,那么久无法及时提供服务;

同时单机的内存等容量有限,无法支持耗能较大的应用;

如果应用的访问并发过大,单机环境无法支持那么大的QPS

 所以,这时就需要多态服务器主机通过主从复制的机制提供更好的应用。

2、主从复制的作用:

1)一主一从模型:

左边的master是主节点,右边的slave是从节点。

如图,假如此时右边是一个空的redis,左边是一个有数据的redis,此时,我做一个复制的操作或复制的命令。那么,左边主节点的数据会向右边传过去。

此时,如果向左边的redis写数据,右边的slave也会有一些操作。

如图,左边有K1、K2、K3、.....、Kn,同样的,右边也会有K1、K2、K3、...、Kn。

它能够起到对主机进行备份的作用。可以为主机发生宕机时提供数据的支援。
2)一主多从模型:

一个master可以有多slave,也就是有多个数据的副本。有利于在master和一台slave或两台slave同时挂掉时,还能够有多个数据备份。

以及可以进行读写分离,达到流量分流。

示例:

3、主从复制作用:

数据副本

扩展读性能

小结:

1) 一个master可以有多个slave

2)一个slave只能有一个master

3)数据流向是单向的,master到slave

三、主从复制配置

1、实现主从复制的方式:

两种实现方式:

1)命令实现:

命令:

redis-6380 > slaveof 127.0.0.1 6379

OK

取消复制(恢复主节点地位):

已写入数据不做清除,原主节点数据也不再写入

命令:

redis-6380 > slaveof no one

OK

2、修改配置(主从配置):

slaveof ip port 

在主节点标记从节点 ip  port

slave-read-only yes

配置从节点只做读操作

3、比较

四、主从配置-操作

  • 命令
  • 配置
  • 主从关系
  • 主从数据

1、编辑配置文件redis.conf

1)主节点配置:

进程id

日志文件

关闭rdb

配置rdb文件名:区别主从

工作目录

2)从节点配置:

从节点复制主节点,指定主节点 ip port

其他配置和主节点一致,只需修改相关名称中的端口号6378为 6379即可

启动主服务器:

主节点状态:

启动从服务器:

从节点状态:

同步测试:

Redis 入门到分布式 (七)Redis复制的原理与优化的更多相关文章

  1. redis入门(15)redis的数据备份和恢复

    redis入门(15)redis的数据备份和恢复

  2. redis入门(14)redis集群下的数据分区存储

    redis入门(10)redis集群下的数据分区存储

  3. Redis 入门到分布式 (五) Redis持久化的取舍和选择

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) Redis持久化的取舍和选择 持久化的作用 RDB AOF RDB和AOF的选择 一.持久化的作用   ...

  4. Redis 入门到分布式 (二)API的理解和使用

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 内容: 通用命令 单线程架构 数据结构和内部编码 一.常用的通用命令: keys       计算所有的 ...

  5. redis入门指南(五)—— 复制与哨兵

    写在前面 学习<redis入门指南>笔记,结合实践,只记录重要,明确,属于新知的相关内容. 一.复制 1.在复制中,数据库分为两类,一类主数据库,一类从数据库,主库用来读写,从库用来读,主 ...

  6. redis入门指南(七)—— 安全、协议、管理工具及命令属性

    写在前面 学习<redis入门指南>笔记,结合实践,只记录重要,明确,属于新知的相关内容. 安全 1.可以使用bind参数绑定一个地址,使redis只接受这个地址的连接. 2.使用requ ...

  7. <Redis> 入门X 分布式锁

    分布式其实就是多进程的程序,当多个进程访问一个资源,会造成问题: 1.资源共享的竞争问题 2.数据的安全性 分布式锁的解决方案: 1.怎么去获取锁 数据库 zookeeper redis 2.怎么释放 ...

  8. Redis 入门到分布式 (八)Redis Sentinel

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) sentinel-目录 主从复制高可用 安装配置 实现原理 架构说明 客户端连接 常见开发运维问题 一. ...

  9. Redis 入门到分布式 (一)Redis初识

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.Redis特性目录 Redis的特性: 速度快 持久化 多种数据结构 支持多种编辑语言 功能丰富 简 ...

随机推荐

  1. Java 将鼠标改为图片的两种方法

    一 图片跟着鼠标移动,鼠标隐藏 int x,y; addMouseMotionListener(this);//设置鼠标监听 public void paint(Graphics g) {  g.dr ...

  2. 内网穿透访问Vue项目的时候出现Invalid Host header解决办法

    适用场景: 在本地的Vue-cli3项目, 需要其他人浏览. 如果没有外网的服务器, 可以把自己的电脑当做服务器. 这时候需要外网的人能访问到自己的电脑. Mac内网穿透工具:natapp Inval ...

  3. Mysql 常用函数(5)- substring 函数

    Mysql常用函数的汇总,可看下面系列文章 https://www.cnblogs.com/poloyy/category/1765164.html substring 的作用 截取指定范围的字符串, ...

  4. C#实现局域网聊天 通讯 Socket TCP 多人

    程序分别为服务端与客户端,服务端创建套接字使用多线程侦听多客户端请求 代码需要引用System.Net:和System.Net.Socket:这两个类 分享源码demo:https://pan.bai ...

  5. Dozer-对象属性映射工具类

    Dozer-对象属性映射工具类 工具类代码: import java.util.List; import java.util.concurrent.CopyOnWriteArrayList; impo ...

  6. Millar Robin模板

    \(Millar Robin\)模板 hdu2138 \(Code\) #include <cstdio> #include <iostream> #include <a ...

  7. Sentinel源码解析二(Slot总览)

    写在前面 本文继续来分析Sentinel的源码,上篇文章对Sentinel的调用过程做了深入分析,主要涉及到了两个概念:插槽链和Node节点.那么接下来我们就根据插槽链的调用关系来依次分析每个插槽(s ...

  8. 基于 abp vNext 和 .NET Core 开发博客项目 - 统一规范API,包装返回模型

    上一篇文章(https://www.cnblogs.com/meowv/p/12916613.html)使用自定义仓储完成了简单的增删改查案例,有心的同学可以看出,我们的返回参数一塌糊涂,显得很不友好 ...

  9. http://blog.itpub.net/28602568/viewspace-759789/

    varchar .varchar2.nvarchar.nvarchar2  -->存储可变的字符串 varchar .varchar2:varchar:汉字全角等字符占2字节,数字.字母均1个字 ...

  10. 接上一篇:vue零基础入门记录

    上一篇的vue项目已经搭建运行了起来,我用惯了idea这里也用的idea打开的项目.貌似其他软件写前端更好. 打开项目的项目路径是这样的 写惯了后台,第一眼看的时候感觉这个项目路径很乱,后面才知道我们 ...