1.集群如何操作

  现在有三台虚拟机,ip分别为100,105,106,将100作为master,其他两台作为slave

  

  1.vim redis.conf

  以前的版本是 slaveof <masterip> <masterport>

  

  我使用的是redis 5.0.3

  所以是 replicaof <masterip><masterport> 分别代表主节点ip和主节点端口

  

  2.修改两个从节点,配置为如下,设置 eplicaof <masterip><masterport> ,masterauth 密码

  

  3.完成配置

2.检查是否配置成功

  重启三台服务器,然后在从节点下输入指令: info replication

  可以看到role是slave,以及主机ip、端口,状态等信息,即代表配置成功。  

  

  master发送命令

  

  在slave端获取

  

  无法在从节点上进行写的操作

  

3.主从复制的原理

3.1 全量同步

  1.slave 第一次连接 或 重连 到 master 上以后,会向 master 发送 sync 的命令

  2.master收到 sync 命令,执行 bgsave 生成 rbd 快照,新的命令会写进缓冲区

  3.master执行完bgsave后,将 rbd 文件发送给各slave节点

  4.slave接收到 rbd 文件,丢弃旧的 rbd 数据,执行新的rbd快照

  5.master发送完rbd快照后,将缓冲区数据发送到slave

  6.slave完成对rbd的载入后,执行master缓冲区的写命令

  

3.2 增量同步

  slave服务器完成初始化,工作正常,主服务器发生写操作同步到从服务器

  增量同步主要是:主服务器每执行一条写命令就会向从服务器发送相同的写命令,从服务器接收并执行收到的命令

3.3 部分同步

  当master服务器断线后,从服务器需要重新发送sync命令,这样会消耗大量服务器 cpu、内存、磁盘,并且传送rdb还会消耗网络资源等

  在redis2.8版本后,部分同步 psync 来执行同步的命令。

  master在内存中给每个slave维护了一份同步日志和同步标识。每个slave和master同步都会携带自己的同步标识和上次同步的最后位置

  当master断线重连后,slave带着自己的同步标识,和上次同步的最后位置去找master,如果slave的偏移量在master同步日志中

  那么slave从偏移量开始的位置继续同步,无需进行全量同步。

3.4 同步策略

  第一次连接,进行全量同步,全量同步结束后,进行增量同步。

  如果断开,尝试部分同步,不行的话,依然采用全量同步。

3.5 部分命令

  通过replconf listening-port 6379

   sync,去向主服务器发送同步命令,此时进入通过输出模式,并不断发送ping包

   

  master写入数据

  

  slave 就会输出从缓冲区来的数据

  

  replica-server-stale-data yes  意味着必须完成 master 同步之后才能做接下来的操作。可以防止数据不一致的情况

  

  缺点:主从复制时,当 master 宕机后,从服务器没办法进行动态选举,从只能读取就的数据。

<Redis> 入门六 主从复制方式的集群的更多相关文章

  1. shell脚本部署redis以及redis主从复制和redis-cluster集群

    # 关于脚本: # 使用root用户执行此脚本,提前关闭selinux: # 执行脚本之前,hostsIP内的IP修改成自己的机器IP: # hostsIp内的IP数量如果有增加或者减少,for循环的 ...

  2. 实现Redis Cluster并实现Python链接集群

    目录 一.Redis Cluster简单介绍 二.背景 三.环境准备 3.1 主机环境 3.2 主机规划 四.部署Redis 4.1 安装Redis软件 4.2 编辑Redis配置文件 4.3 启动R ...

  3. Linux下redis 的部署、主从与集群

    老男孩Python全栈6期——redis--------------------------Linux 操作系统 默认的内存管理机制RSS:page cache:anno page:Linux操作系统 ...

  4. redis 5.0.3 讲解、集群搭建

    REDIS 一 .redis 介绍 不管你是从事Python.Java.Go.PHP.Ruby等等... Redis都应该是一个比较熟悉的中间件.而大部分经常写业务代码的程序员,实际工作中或许只用到了 ...

  5. Redis安装(单机及各类集群,阿里云)

    Redis安装(单机及各类集群,阿里云) 前言 上周,我朋友突然悄悄咪咪地指着手机上的一篇博客说,这是你的博客吧.我看了一眼,是之前发布的<Rabbit安装(单机及集群,阿里云>.我朋友很 ...

  6. Redis学习笔记(九)——集群

     一.概述 Redis Cluster与Redis3.0.0同时发布,以此结束了Redis无官方集群方案的时代. Redis Cluster是去中心化,去中间件,也就是说,集群中的每个节点都是平等的关 ...

  7. Tomcat 集群模式下 Session 更新 Bug (redis memcached 及tomcat自已的集群)

    从 excel 中导入数据入系统,我们用的是先上传文件至服务器再分析所上传的文件逐行导入. 就是执行了一循环,在当前循环位置标识一下客户端就知道执行的进度了,以前的方式 是用 session.setA ...

  8. Redis详解(七)——集群

    Redis详解(七)--集群 ​Redis3.0版本之前,可以通过Redis Sentinel(哨兵)来实现高可用 ( HA ),从3.0版本之后,官方推出了Redis Cluster,它的主要用途是 ...

  9. Redis系列5:深入分析Cluster 集群模式

    Redis系列1:深刻理解高性能Redis的本质 Redis系列2:数据持久化提高可用性 Redis系列3:高可用之主从架构 Redis系列4:高可用之Sentinel(哨兵模式) 1 背景 前面我们 ...

随机推荐

  1. 解决 iphone5 4 inch 屏 app黑边问题

    你需要一张640*1138的预加载图(launch image).在工程>TARGETS 中添加,系统将自动将其重命名为Default-568h@2x.png.

  2. Windows 程序设计 笔记

    知识点 双字节字符集和Unicode字符集有何区别?采用双字节字符集有何问题 双字节字符集(DBCS)编码是0-255,DBCS含有1字节代码与2字节代码,而Unicode是统一的16位系统,这样就允 ...

  3. JAVA启动参数三:非Stable参数

    前面我们提到用-XX作为前缀的参数列表在jvm中可能是不健壮的,SUN也不推荐使用,后续可能会在没有通知的情况下就直接取消了:但是由于这些参数中的确有很多是对我们很有用的,比如我们经常会见到的-XX: ...

  4. New Year Tree CodeForces -620E

    这个题有一个技巧:把颜色压到一个long long 上. #include<cstdio> #include<algorithm> #include<cstring> ...

  5. 题解报告:hdu1995汉诺塔V(递推dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1995 Problem Description 用1,2,...,n表示n个盘子,称为1号盘,2号盘,. ...

  6. 转 ORA-00054 的解决方法

    统有一个不用的索引,想删除这个索引, SQL> drop index GPSTIME_GLOBAL_INDEX  2  /drop index GPSTIME_GLOBAL_INDEX      ...

  7. commons-lang常用工具类StringEscapeUtils使用--转

    https://my.oschina.net/ydsakyclguozi/blog/341496 在apache commons-lang(2.3以上版本)中为我们提供了一个方便做转义的工具类,主要是 ...

  8. 完美单例宏定义(兼容ARC和MRC),项目中可以直接使用

     单例模式: 1.永远只分配一块内存来创建对象 2.提供一个类方法, 返回内部唯一的一个对象(一个实例) 3.最好保证init方法也只初始化一次 写一个宏定义文件,传入宏定义函数名,自动生成符合类名的 ...

  9. 行内元素对齐各种问题--从line-height和vertical-align的角度分析

    最近研究行内元素的对齐问题,发现img不管怎么设置,下边都有一块留白,强迫症无法忍受未知,于是开始了查阅探索之旅. 辗转来到张鑫旭的博客,他对行内盒子模型做了详细的介绍,包括“幽灵节点”,“line- ...

  10. Android Studio中找出不再使用的资源

    顶部Analyze菜单中选择Run Inspection by Name 在弹出的输入框中输入unused resources