分布式系统本质是通过低廉的硬件攒在一起以获得更好的吞吐量、性能以及可用性等。一台设备坏了,可以通过负载均衡和路由到其他设备上。分布式系统有一些通用的设计策略,首先要解决心跳问题。一台服务器判定存活状态,才能执行任务,否则则不能。在分布式环境下,有几个问题是普遍关心的,我们称之为设计策略:

  • 如何监测你还活着?
  • 如何保障高可用?
  • 容错处理。
  • 重试机制。
  • 负载均衡。

心跳检测

在分布式环境中,存在非常多的节点(Node),其实质是这些节点分担任务的运行、计算或者程序逻辑处理。那么就有一个非常重要的问题,如何监测一个节点出现了故障乃至无法工作了?具体的场景可以是主备服务之间的切换,也可以是一个管理服务器来管理具体的工作节点。无论怎样,都需要解决“判定某节点无法工作”这一命题。

传统解决这一命题是采用心跳检测的手段,如同通过仪器对病人进行一些检测诊断一样。

如下图所示,当Server没有收到节点Node3发送的心跳时,Server认为Node3失联。失联代码并不确定是否是Node3故障,有可能是Node3处于繁忙状态,导致调用检测超时;也有可能是Server与节点C之间链路出现故障或闪断。所以心跳不是万能的,收到心跳可以确认节点正常,但是收不到心跳却不能确认该节点已经宣告“死亡”。

Client请求Server,则Server需要和需要分派的Node1-3保持连接,得到返回,说明状态没问题,可以分派。我们刚才已经说过了,没有返回不代表宕机,有一些具体的做法来帮助我们做决定,一般分为两类:周期检测心跳机制、累计失效检测机制。这里简单说一下周期检测心跳机制。Server端每间隔t秒向Node集群发起检测请求,设定超时时间,如果超过超时时间,则判断“死亡”。这里的超时时间设置带有随意性,容易误判。进一步,可以统计实际检测Node的返回时间,包括得到一定周期内的最长时间。那么可以根据现有没有正确返回的时间在历史统计的分布中计算得到“死亡”概率,同时对于宣告濒临死亡的节点可以发起有限次数的重试,以作进一步判定。心跳检测本身也是有效资源利用和成本之间的一种权衡,如果迟迟不能判断节点是否“死亡”,会影响业务逻辑的处理。通过周期检测心跳机制、累计失效检测机制可以帮助判断节点是否“死亡”,如果判断“死亡”,可以把该节点踢出集群。

高可用设计

系统高可用性的常用设计模式包括三种:主备(Master-Slave)、互备(Active-Active)和集群(Cluster)模式。

主备模式

主备模式就是Active-Standby模式,当主机宕机时,备机接管主机的一切工作,待主机恢复正常后,按使用者的设定以自动(热备)或手动(冷备)方式将服务切换到主机上运行。在数据库部分,习惯称之为MS模式。MS模式即Master/Slave模式,这在数据库高可用性方案比较常用,如下图所示。

此类方案比较成熟,比如MySQL很早就具备相应的软件套装。但存在Master到Slave的数据延迟风险,尤其是跨地域复制。

互备模式

互备模式指两台主机同时运行各自的服务工作且相互检测情况。在数据库高可用部分,常见的互备是MM模式。MM模式即Multi-Master模式,指一个系统存在多个master,每个master都具有read-write能力,需根据时间戳或业务逻辑合并版本。比如分布式版本管理系统git可以理解成multi-master模式,具备最终一致性。

机房级异常的示例,也是一种Master-Master的解决方案,如下图所示。机房H、K同时具备全套服务能力(读能力和写能力),而数据库之间需要通过同步来保障一致性。当然对于K机房的备库则在机房不可用的时候发挥作用。

集群模式

集群模式是指有多个节点在运行,同时可以通过主控节点分担服务请求,比如zookeeper。集群模式要特别解决主控节点本身的高可用问题。下面是TFS案例,如下图所示。

TFS涉及到NameServer、DataServer两类节点。NameServer存放了元数据,而具体的业务数据存放于DataServer。多个DataServer就是集群模式的运行状态。另外为了保障NameServer的高可用,通过Heart Agent机制做心跳检测来负责NameServer的主备切换。

容错性

容错顾名思义就是IT系统对于错误包容的能力,这里的容错确切的说是容故障(Fault),而并非容错误(Error)。

以前文提及的TFS为例,TFS集群需要容错(一个集群宕掉咋办?)、NameServer需要容错、DataServer的容错。NameServer的容错机制是通过主备切换来完成。NameServer主要管理了DataServer和Block之间的关系。如每个DataServer拥有哪些Block,每个Block存放在哪些DataServer上等。同时,NameServer采用了HA结构,一主一备,主NameServer上的操作会重放至备NameServer。如果主NameServer出现问题,可以实时切换到备NameServer。

另外NameServer和DataServer之间也会有定时的heartbeat,DataServer会把自己拥有的Block发送给NameServer。NameServer会根据这些信息重建DataServer和Block的关系。

容错的处理是保障分布式环境下相应系统的高可用性或者健壮性,一个典型的案例就是对于缓存失效雪崩问题的解决方案。

假设有一个业务,用户查询不到数据,可能是数据库没有,也可能是未知异常,用户可以间隔一定时间后重试,那么可以这样设计缓存容错方案。我们来具体看一下这个例子,如下3个图所示。

     

上图三个图会有什么问题呢?我们在项目中使用缓存通常都是缓存通常都是先检查缓存中是否存在,如果存在直接返回缓存内容,如果不存在就直接查询数据库然后再缓存查询结果返回。这个时候如果我们查询得某一个数据在缓存中一直不存在,就会造成每一次请求都查询DB,这样缓存就失去了意义,在流量大时,可能DB就挂掉了。

那这种问题有什么好办法解决呢?要是有人利用不存在的key频繁攻击我们的应用,这就是漏洞。一个比较巧妙的方法是,可以将这个不存在的key预先设定一个值。比如,key="&&"。在返回这个&&值的时候,我们的应用就可以认为这是不存在的key预先设定一个值。比如,key="&&"。在返回这个&&值的时候,我们的应用就可以认为这时不存在的key,那我们的应用就可以决定是否继续等待继续访问,还是放弃掉这次操作。如果继续等待访问,过一个时间轮询点后,再次请求这个key,如果取得值不再是&&,则可以认为这时候key有值了,从而避免了透传到数据库,把大量的类似请求挡在了缓存之中。

负载均衡

负载均衡集群:其关键在于使用多台集群服务器共同分担计算任务,把网络请求及计算分配到集群可用服务器上去,从而达到可用性及较好的用户操作体验。下图所示就是一个示意图,不同的用户User1、User2、User3访问应用,通过负载均衡器分配到不同的节点。

负载均衡器有硬件解决方案,也有软件解决方案。硬件解决方案有著名的F5,软件有LVS、HAproxy、Nginx等。

以Nginx为例,负载均衡有以下几种策略:

  • 轮询:即Round Robin,根据Nginx配置文件中的顺序,依次把客户端的Web请求分发到不同的后端服务器。
  • 最少连接:当前谁连接最少,分发给谁。
  • IP地址哈希:确定相同IP请求可以转发给同一个后端节点处理,以方便session保持。
  • 基于权重的负载均衡:配置Nginx把请求更多的分发到高配置的后端服务器上,把相对较少的请求分发到低配服务器。

分布式:分布式系统设计策略。相关推荐

  1. 二、分布式系统设计策略

    二.分布式系统设计策略 分布式系统本质是通过低廉的硬件攒在一起以获得更好的吞吐量.性能以及可用性等. 在分布式环境下,以下几个问题是普遍关心的,我们称之为设计策略: 如何检测当前节点还活着? 如何保障 ...

  2. 分布式爬虫系统设计、实现与实战:爬取京东、苏宁易购全网手机商品数据+MySQL、HBase存储

    1 概述 在不用爬虫框架的情况,经过多方学习,尝试实现了一个分布式爬虫系统,并且可以将数据保存到不同地方,类似MySQL.HBase等. 基于面向接口的编码思想来开发,因此这个系统具有一定的扩展性,有 ...

  3. 高可用系统设计 | 分布式限流策略:计数器算法、漏桶算法、令牌桶算法

    文章目录 限流 什么是限流? 分布式限流 限流算法 计数器算法 固定窗口计数器 滑动窗口计数器 漏桶算法 令牌桶算法 限流 什么是限流? 限流可以认为服务降级的一种,限流就是限制系统的输入和输出流量已 ...

  4. 分布式爬虫系统设计、实现与实战:爬取京东、苏宁易购全网手机商品数据+MySQL、HBase存储...

    http://blog.51cto.com/xpleaf/2093952 1 概述 在不用爬虫框架的情况,经过多方学习,尝试实现了一个分布式爬虫系统,并且可以将数据保存到不同地方,类似MySQL.HB ...

  5. 分布式爬虫系统设计、实现与实战

    1 概述 在不用爬虫框架的情况,经过多方学习,尝试实现了一个分布式爬虫系统,并且可以将数据保存到不同地方,类似MySQL.HBase等. 基于面向接口的编码思想来开发,因此这个系统具有一定的扩展性,有 ...

  6. 分布式电子邮件系统设计--转载

    原文地址:http://www.mailer.com.cn/Products/MegaIntro1.htm 设计目标 邮件系统在当今社会,作为一种基础通讯平台,已经不单纯是简单收发邮件,而是成为互联网 ...

  7. 【架构】分布式追踪系统设计与实现

    分布式追踪系统 使用 Zipkin 和 Brave 实现分布式系统追踪(基础篇) - 推酷OpenZipkin · A distributed tracing systemTwitter zipkin ...

  8. 6位顺序号生成_分布式id生成策略,我和面试官扯了一个半小时

    一.分布式系统带来ID生成挑战 在分布式系统中,往往需要对大量的数据如订单.账户进行标识,以一个有意义的有序的序列号来作为全局唯一的ID. 而分布式系统中我们对ID生成器要求又有哪些呢? 全局唯一性: ...

  9. delphi 获取webbrowser文本框id内数值_分布式 ID 生成策略

    对于系统中的一组数据而言,必不可少地对应有唯一标识.简单的单体应用可以使用数据库的自增 ID 作为唯一标识.而在复杂的分布式系统中,就需要一些特定的策略去生成对应的分布式 ID. 常见的项目中 ID ...

最新文章

  1. Skype for Business Server 2015-07-边缘服务器-3-部署
  2. linxu命令之cp 拷贝整个目录下的所有文件
  3. 字符集GBK和UTF8的区别说明
  4. 道客巴巴vip账号共享2020_腾讯视频VIP怎么两个手机通用?
  5. 产品观念:更好的捕鼠器_故事很重要:为什么您需要成为更好的讲故事的人
  6. Python中os模块使用方法
  7. dom4j解析xml的简单实用
  8. 删除字符,用外部函数
  9. 你有程序员朋友吗?告诉他,100 万等他来拿
  10. 权限设计(资源权限和数据权限)
  11. java snmp walk,snmpwalk命令常用方法总结(转)
  12. ITRF框架转换程序实现的理论
  13. 第十二章(项目采购管理)知识点
  14. 资料:基于MPSOC XCZU15EG-2FFVB1156I 的PCIe FMC 光纤接口处理卡设计资料保存
  15. 字体下面有背景颜色css,CSS 颜色 字体 背景 文本 边框 列表 display属性
  16. 职业与生活规划是否必要?回答因人而异。但规划至少会给人带来以下好处。
  17. python用七巧板图片画个图_画一个太大而不能放进一个七巧板的图像
  18. MYSQL中如何创建存储过程和存储函数(上篇)
  19. 什么是进程,进程的特征
  20. C++ 开源游戏服务器框架

热门文章

  1. 细看10个不同类型的社交平台
  2. window.open父子页面,子页面关闭回调事件样例
  3. java 使用HttpC'lient 解析webService
  4. 怎么把PDF拆分开成一张一张的
  5. springmvc接收请求参数(springmvc教程二)
  6. 删除只读属性的文件夹及其子文件
  7. MySQL如何修改主键
  8. 使用WPF与C#实现鼠标画线
  9. android记账app开发全过程,android开发实战-记账本APP(一)
  10. 榨干运营成本:一亿之后再省两亿