Redis的三种集群模式

Redis有三种集群模式,第一个就是主从模式,第二种“哨兵”模式,第三种是Cluster集群模式,第三种的集群模式是在Redis 3.x以后的版本才增加进来的,这里先说Redis第一种集群模式:主从集群模式。

主从集群模式:

实现主从复制(Master-Slave Replication)的工作原理:Slave从节点服务启动并连接到Master之后,它将主动发送一个SYNC命令。Master服务主节点收到同步命令后将启动后台存盘进程,同时收集所有接收到的用于修改数据集的命令,在后台进程执行完毕后,Master将传送整个数据库文件到Slave,以完成一次完全同步。而Slave从节点服务在接收到数据库文件数据之后将其存盘并加载到内存中。此后,Master主节点继续将所有已经收集到的修改命令,和新的修改命令依次传送给Slaves,Slave将在本次执行这些数据修改命令,从而达到最终的数据同步。

主从复制的配置很简单,主要操作从节点的配置文件,主节点不需要任何改动。我们可以使用info查看role角色即可知道是主服务或从服务。

常用命令:

根据配置文件启动redis: ./redis-server ../etc/redis.conf
启动redis客户端:redis-cli -p port
Slaver连接Master:slaveof host:ip (测试时使用slaveof手动连接master,正式环境使用配置文件)
查看主从信息:info Replication

具体配置(测试模拟):

1、在同一台机器上,按照1主1从的最简单的结构搭建,即1个Master,1个Slaver节点

2、Redis配置文件redis.conf的配置:(ps:如果master节点设置了密码,子节点的配置文件就要加上:masterauth <master-password>)

3、配置完后2个节点都是master,通过info Replication查看角色信息:

4、配置主从节点,在从节点上执行:

127.0.0.1:7001> slaveof 127.0.0.1 7000
OK

主从redis的日志显示:显示数据同步成功,主从设置成功:

这时一个节点是master,一个是slaver,再通过info Replication查看角色信息:

5、Master节点设置key后异步同步到Slaver节点;Slaver节点只能读取数据,但不能有写操作

6、如果master节点挂掉,手动将slaver节点升级为Master(命令:slaveof no one 手动将Slaver节点升级为Master节点)
   操作步骤如下:
    a) Master节点: Shutdown关闭节点
    b) Slaver节点:slaveof no one将其升级为Master节点
    c) 原来的Master节点:重新启动后,可以使用slaveof 127.0.0.1 7001 连接Slaver将其视为Master节点,自己成为Slaver节点

主从模式的优缺点

  • 优点:
  1. Master可以对应多个Slaver,甚至Slave同样可以接受其它Slaves的连接和同步请求(即slaveof 一个从节点ip+端口),这样可以有效的分担Master的同步压力
  2. Master可读可写,Master写入后立即返回,几乎同时将写入异步同步到各个Slaver,所以基本上延迟可以忽略;而Slaver只能读不能写,分担了Master的读操作压力;总体上实现了读写分离
  3. Master是以非阻塞的方式为Slaves提供服务,在Master-Slave同步期间,客户端仍然可以提交查询或修改请求;Slave同样是以非阻塞的方式完成数据同步,在同步期间,如果有客户端提交查询请求,Redis则返回同步之前的数据
  • 缺点:
  1. 主从模式不具备自动容错和恢复功能,主机从机的宕机都会导致部分读写请求失败,需要等待机器重启、slaveof no one命令切换主从,手动切换前端的IP这三步才能恢复。
  2. 主机宕机,如果宕机前有部分数据未能及时同步到从机,即使切换IP后还会引入数据不一致的问题,降低了系统的可用性。
  3. Redis的主从复制采用全量复制,复制过程中主机会fork出一个子进程对内存做一份快照,并将子进程的内存快照保存为文件发送给从机,这一过程需要确保主机有足够多的空余内存。若快照文件较大,受制于网络波动,对集群的性能会产生较大的影响。
  4. 不能水平扩容,这个模式的高可用特性会受到Master主节点内存的限制。

总结

redis的主从模式很简单,在实际的生产环境中是很少使用的,不建议使用是由它的缺点造成的,在数据量非常大的情况,或者对系统的高可用性要求很高的情况下,主从模式是不稳定的。虽然这个模式很简单,但是这个模式是其他模式的基础。

参考:https://www.cnblogs.com/PatrickLiu/p/8426610.html

https://www.cnblogs.com/gossip/p/5992716.html

redis之集群一:主从的更多相关文章

  1. redis搭建集群和主从

    说明 Redis集群至少需要3个节点,来支持投票容错机制,每个节点都有从节点,所有最少是6个服务(3个主3个从) 因为集群内置了16384个slot(哈希槽),并且把所有的物理节点映射到了这16384 ...

  2. redis sentinel 集群配置-主从切换

    1.配置redis master,redis slave(配置具体操作见上文http://www.cnblogs.com/wangchaozhi/p/5140469.html). redis mast ...

  3. redis 非集群的主从配置及切换

    单纯的master-slave不能称之为集群,只能叫做读写分离.此案例只针对master为单点服务,且程序端写死master为可写,slave为只读.若master宕机则不可用,若主从未开启持久化,不 ...

  4. python连接redis哨兵集群

    一.redis集群模式有多种, 哨兵模式只是其中的一种实现方式, 其原理请自行谷歌或者百度 二.python 连接 redis 哨兵集群 1. 安装redis包 pip install redis 2 ...

  5. 搭建分布式 Redis Cluster 集群与 Redis 入门

    目录 Redis 集群搭建 Redis 是啥 集群(Cluster) Redis Cluster 说明 Redis Cluster 节点 Redis Cluster 集群模式 不能保证一致性 创建和使 ...

  6. Redis集群(九):Redis Sharding集群Redis节点主从切换后客户端自动重新连接

    上文介绍了Redis Sharding集群的使用,点击阅读 本文介绍当某个Redis节点的Master节点发生问题,发生主从切换时,Jedis怎样自动重连新的Master节点 ​一.步骤如下: 1.配 ...

  7. Redis Cluster集群主从方案

    本文介绍一种通过Jedis和Cluster实现Redis集群(主从)的高可用方案,该方案需要使用Jedis2.8.0(推荐),Redis3.0及以上版本(强制). 附:Redis Cluster集群主 ...

  8. Redis集群(主从模式)

    主从模型   在Redis的集群当中,每个节点(实例)都有一个身份:Master或者Slave,Master:主要负责数据写入,Slave一般提供数据读取,Master与Slave之间是一对多关系,M ...

  9. Redis集群的主从切换研究

    目录 目录 1 1. 前言 1 2. slave发起选举 2 3. master响应选举 5 4. 选举示例 5 5. 哈希槽传播方式 6 6. 一次主从切换记录1 6 6.1. 相关参数 6 6.2 ...

  10. redis集群(主从配置)

    市面上太多kv的缓存,最常用的就属memcache了,但是memcache存在单点问题,不过小日本有复制版本,但是使用的人比较少,redis的出现让kv内存存储的想法成为现实.今天主要内容便是redi ...

随机推荐

  1. js日期格式化-----总结

    1. // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 ...

  2. C# 高性能对象映射

    1.之前在使用AutoMapper 框架感觉用着比较不够灵活,而且主要通过表达式树Api 实现对象映射 ,写着比较讨厌,当出现复杂类型和嵌套类型时性能直线下降,甚至不如序列化快. 2.针对AutoMa ...

  3. modelViewSet 获取未序列化的数据

    1 views/  perform_create 方法的使用  获取未序列化的数据 def perform_create(self, serializer): user_obj=serializer. ...

  4. 自动化管理平台rundeck的安装方法

    简介 RunDeck 是用 Java/Grails 写的开源工具,帮助用户在数据中心或者云环境中自动化各种操作和流程.通过命令行或者web界面,用户可以对任意数量的服务器进行操作,大大降低了对服务器自 ...

  5. numpy和pandas-数据分析模块

    应用:1.数据分析 2.深度学习 3.机器学习 运算速度快:numpy 和 pandas 都是采用 C 语言编写, pandas 又是基于 numpy, 是 numpy 的升级版本. 消耗资源少:采用 ...

  6. Gradle 是干什么吃的?

    Gradle维基解释:Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化建构工具.它使用一种基于Groovy的特定领域语言来声明项目设置,而不是传统的XML.当前其支 ...

  7. 企业微信JS-SDK实现会话聊天功能

    vue引入企业微信JS-SDK实现会话聊天功能 这两天在做一个对接企业微信实现会话聊天的功能, 发现企业微信文档这块儿做的不是特别详细,网上搜索也没找到特别完整的流程. 期间也踩了不少的坑, 在此进行 ...

  8. 神经网络高维互信息计算Python实现(MINE)

    论文 Belghazi, Mohamed Ishmael, et al. " Mutual information neural estimation ."  Internatio ...

  9. 5分钟看懂系列:Python 线程池原理及实现

    概述 传统多线程方案会使用"即时创建, 即时销毁"的策略.尽管与创建进程相比,创建线程的时间已经大大的缩短,但是如果提交给线程的任务是执行时间较短,而且执行次数极其频繁,那么服务器 ...

  10. 你真的理解了java单例模式吗?讲别人都忽略的细节!

    前言:老刘这篇文章敢做保证,java的单例模式讲的比大多数的技术博客都要好,讲述别人技术博客都没有的细节!!! 1 java单例模式 直接讲实现单例模式的两种方法:懒汉式和饿汉式,单例模式的概念自己上 ...