热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【随笔记】Redis(二)架构模式

【随笔记】Redis(二)由简入繁,水滴石穿。Redis的架构模式单机版直接说,就是只有一个redis,坏了就没得用那种。特点:简单,很简单。缺点:存储容量有限制,取决于所在服务器




【随笔记】Redis(二)

由简入繁,水滴石穿。



Redis 的架构模式


单机版


直接说,就是只有一个redis,坏了就没得用那种。



  • 特点:简单,很简单。
  • 缺点:
    • 存储容量有限制,取决于所在服务器的能力
    • 处理能力有限,也取决于所在服务器的能力
    • 高可用性无,没有高可用,坏了就没得用

主从复制


高端点的单机版,Redis的复制(replication)功能允许用户根据一个Redis服务器来创建多个任意的复制品,其中被复制的服务器就是主服务器(master),而通过复制出来的服务器就是从服务器(slave)。只要主从服务器之间的网络连接正常,主从服务器之间就具有相同的数据,主服务器会一直将自身数据同步给从服务器,保证主从服务器上面的数据相同。



  • 特点:
    • master、slave两个角色
    • master、slave数据是相同的
    • 可以降低master读数据压力,可以将读操作交给slave
  • 缺陷:
    • 没有高可用,master宕机后还是没得用
    • slave为master减轻读压力,但是master还是存在写压力

哨兵模式


高端模式,解决了高可用、自动进行故障转移。



  • 监控(monitoring):Sentinel会不断检查主服务器和从服务器是否正常工作;
  • 提醒(Notification):当被监控的某个Redis服务器出现问题,Sentinel可以通过API向管理员或者其他程序发送通知;
  • 自动故障迁移(Automatic failover): 当一个主服务器不能正常工作,Sentinel会进行一次自动故障迁移。
  • 特点:
    • 高可用
    • 监控所有节点
    • 可以自动故障迁移
  • 缺点:
    • 主从模式切换时间中,数据会丢失
    • master写压力没有解决

集群模式(Proxy)


高端玩法。使用Twitter开源的Twemproxy,一个Redis和Memcache快速/轻量级代理服务器,他是一个快速的单线程代理程序,支持Memcached ASCII协议和Redis协议。



  • 特点鲜明:
    • 1.支持多种hash算法:MD5、CRC16、CRC32、CRC32a、hsieh、murmur、Jenkins;
    • 2.支持自动删除失败节点。
    • 3.后端Sharding分配逻辑对业务透明,业务的读写方式和操作单个Redis一致;
  • 缺点:
    • 维护高可用的成本增加,因为同样要维护proxy的高可用

集群模式(直连)


Redis 3.0后版本支持Redis-cluster集群,采用的是无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。



  • 特点:
    • 无中心架构,少了proxy代理层
    • 数据按照slot存储分布在多个节点,节点间数据共享,可动态调整数据分布
    • 可扩展性,节点可以动态增加或者减少
    • 高可用性,当有节点不可用时,集群仍然可用,可以增加slave做备份数据副本
    • 实现故障自动failover,节点之间通过gossip协议交换状态信息,通投票机制完成slave到master的角色提升
  • 缺点:
    • 资源隔离性差,很容易出现相互影响
    • 数据通过异步复制,强一致性不能保证


推荐阅读
  • C1、缓存的意义说到分布式系统基本上就离不开缓存,在高并发,大流量的场景下缓存更是扮演着重要的角色。所以作为一个分布式系统的开发人员是必须熟练掌握缓存的使用与设计。下面是一张简单的 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • 面试经验分享:华为面试四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试
    最近有朋友去华为面试,面试经历包括四轮电话面试、一轮笔试、一轮主管视频面试、一轮hr视频面试。80%的人都在第一轮电话面试中失败,因为缺乏基础知识。面试问题涉及 ... [详细]
  • 玩转直播系列之消息模块演进(3)
    一、背景即时消息(IM)系统是直播系统重要的组成部分,一个稳定的,有容错的,灵活的,支持高并发的消息模块是影响直播系统用户体验的重要因素。IM长连接服务在直播系统有发挥着举足轻重的 ... [详细]
  • PHP语言之所以能有今天的地位,得益于PHP语言设计者一直遵从实用主义,将技术的复杂性隐藏在底层。PHP语言入门简单,容易掌握,程序健壮性好。 ... [详细]
  • 一、NoSQL数据库简介Web1.0的时代,数据访问量很有限,用一夫当关的高性能的单点服务器可以解决大部分问题。随着Web2.0的时代的到来,用户访问量大幅度提升,同时产生了大量的 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了Hyperledger Fabric外部链码构建与运行的相关知识,包括在Hyperledger Fabric 2.0版本之前链码构建和运行的困难性,外部构建模式的实现原理以及外部构建和运行API的使用方法。通过本文的介绍,读者可以了解到如何利用外部构建和运行的方式来实现链码的构建和运行,并且不再受限于特定的语言和部署环境。 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • http:simple-is-better.comnews1047Firefly是免费、开源、稳定、快速扩展、能“热更新”的分布式游戏服务器端框架,采用Python编 ... [详细]
author-avatar
骆树真次_902
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有