Redis 入门到分布式 (七)Redis复制的原理与优化
一、目录
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复制的原理与优化的更多相关文章
- redis入门(15)redis的数据备份和恢复
redis入门(15)redis的数据备份和恢复
- redis入门(14)redis集群下的数据分区存储
redis入门(10)redis集群下的数据分区存储
- Redis 入门到分布式 (五) Redis持久化的取舍和选择
个人博客网:https://wushaopei.github.io/ (你想要这里多有) Redis持久化的取舍和选择 持久化的作用 RDB AOF RDB和AOF的选择 一.持久化的作用 ...
- Redis 入门到分布式 (二)API的理解和使用
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 内容: 通用命令 单线程架构 数据结构和内部编码 一.常用的通用命令: keys 计算所有的 ...
- redis入门指南(五)—— 复制与哨兵
写在前面 学习<redis入门指南>笔记,结合实践,只记录重要,明确,属于新知的相关内容. 一.复制 1.在复制中,数据库分为两类,一类主数据库,一类从数据库,主库用来读写,从库用来读,主 ...
- redis入门指南(七)—— 安全、协议、管理工具及命令属性
写在前面 学习<redis入门指南>笔记,结合实践,只记录重要,明确,属于新知的相关内容. 安全 1.可以使用bind参数绑定一个地址,使redis只接受这个地址的连接. 2.使用requ ...
- <Redis> 入门X 分布式锁
分布式其实就是多进程的程序,当多个进程访问一个资源,会造成问题: 1.资源共享的竞争问题 2.数据的安全性 分布式锁的解决方案: 1.怎么去获取锁 数据库 zookeeper redis 2.怎么释放 ...
- Redis 入门到分布式 (八)Redis Sentinel
个人博客网:https://wushaopei.github.io/ (你想要这里多有) sentinel-目录 主从复制高可用 安装配置 实现原理 架构说明 客户端连接 常见开发运维问题 一. ...
- Redis 入门到分布式 (一)Redis初识
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 一.Redis特性目录 Redis的特性: 速度快 持久化 多种数据结构 支持多种编辑语言 功能丰富 简 ...
随机推荐
- Java 将鼠标改为图片的两种方法
一 图片跟着鼠标移动,鼠标隐藏 int x,y; addMouseMotionListener(this);//设置鼠标监听 public void paint(Graphics g) { g.dr ...
- 内网穿透访问Vue项目的时候出现Invalid Host header解决办法
适用场景: 在本地的Vue-cli3项目, 需要其他人浏览. 如果没有外网的服务器, 可以把自己的电脑当做服务器. 这时候需要外网的人能访问到自己的电脑. Mac内网穿透工具:natapp Inval ...
- Mysql 常用函数(5)- substring 函数
Mysql常用函数的汇总,可看下面系列文章 https://www.cnblogs.com/poloyy/category/1765164.html substring 的作用 截取指定范围的字符串, ...
- C#实现局域网聊天 通讯 Socket TCP 多人
程序分别为服务端与客户端,服务端创建套接字使用多线程侦听多客户端请求 代码需要引用System.Net:和System.Net.Socket:这两个类 分享源码demo:https://pan.bai ...
- Dozer-对象属性映射工具类
Dozer-对象属性映射工具类 工具类代码: import java.util.List; import java.util.concurrent.CopyOnWriteArrayList; impo ...
- Millar Robin模板
\(Millar Robin\)模板 hdu2138 \(Code\) #include <cstdio> #include <iostream> #include <a ...
- Sentinel源码解析二(Slot总览)
写在前面 本文继续来分析Sentinel的源码,上篇文章对Sentinel的调用过程做了深入分析,主要涉及到了两个概念:插槽链和Node节点.那么接下来我们就根据插槽链的调用关系来依次分析每个插槽(s ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - 统一规范API,包装返回模型
上一篇文章(https://www.cnblogs.com/meowv/p/12916613.html)使用自定义仓储完成了简单的增删改查案例,有心的同学可以看出,我们的返回参数一塌糊涂,显得很不友好 ...
- http://blog.itpub.net/28602568/viewspace-759789/
varchar .varchar2.nvarchar.nvarchar2 -->存储可变的字符串 varchar .varchar2:varchar:汉字全角等字符占2字节,数字.字母均1个字 ...
- 接上一篇:vue零基础入门记录
上一篇的vue项目已经搭建运行了起来,我用惯了idea这里也用的idea打开的项目.貌似其他软件写前端更好. 打开项目的项目路径是这样的 写惯了后台,第一眼看的时候感觉这个项目路径很乱,后面才知道我们 ...