`
76052186
  • 浏览: 36892 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

集群的可扩展性及其分布式体系结构之七--网络负载平衡常见问题

阅读更多

集群的可扩展性及其分布式体系结构之七--网络负载平衡常见问题

developerWorks
文档选项
<noscript></noscript>
将此页作为电子邮件发送

将此页作为电子邮件发送

<!----><!---->
<!---->

级别: 初级

林凡 (iamafan@21cn.com)厦门大学

2003 年 4 月 09 日

阔别已久的集群系列终于又和大家见面了,埋头研究了一段时间,也实现了一些系统的具体实现,从中获得了不少体验。接下来准备就遇到的问题和体会同广大爱好者一同交流。这一章主要介绍了在进行一个负载平衡项目中遇到的一些错误。
<!----><!----><!---->

常见的错误

集群系统的设计是复杂的,特别在处理通信和软件架构上面,有很多令人意想不到的问题,层出不穷。以下是笔者在部署集群系统的时候遇到的频率较高的问题,且作为抛砖引玉,希望广大爱好者可以加以讨论:

1. 溢出

如果有太多网络流量要处理,就会导致包丢失和发往目的节点的包阻塞,这时就会导致溢出。溢出可能发生在主控平衡器,也可能是在各服务节点。由于平衡器在处理能力上往往比节点的要大的多,就很可能是平衡器的流量很平稳但是某些较弱的节点溢出;反过来平衡器如果超载则会导致将要转发的数据流丢失或阻塞。

典型的节点溢出情况:

在运行Apache的节点中,当系统承受太多的Http请求时,由于节点的处理能力不足(内存、CPU),导致Apache无法响应新的HTTP连接请求,出现"假死"的状态;而此时该节点依然能够响应ICMP数据。可以通过Apache自带的性能测试工具ab试验一下:

1、 选择一台测试机,运行

ab -n 600000 -c 2000 http://URL

2、 到URL所在的节点运行Top,观察系统的负载。

3、 尝试在某台浏览器上访问该节点的Web服务。

4、 尝试向该主机发出ICMP请求。

结论:你会观察到基本无法访问该机器的Web服务。如果在集群中出现这样的节点,这个节点就应该能够被负载平衡器识别出来并将它从集群中删除

在处理TCP/IP协议是最常见的溢出错误就是TCP包超时。由于发送的TCP包需要等待确认信息,溢出错误使得确认信息无法返回,引发用户程序的再次尝试发送相同的请求包(这会产生更多的流量),最终造成恶性循环直至这个连接不可用。

2. 挨饿--负载不均衡

如果有太多网络流量要处理,就会导致包丢失和发往目的节点的包阻塞,这时就会导致溢出。溢出可能发生在主控平衡器,也可能是在各服务节点。由于平衡器在处理能力上往往比节点的要大的多,就很可能是平衡器的流量很平稳但是某些较弱的节点溢出;反过来平衡器如果超载则会导致将要转发的数据流丢失或阻塞。

在集群内部,一个节点如果和其他节点相比,没有得到足够的流量,或者这个节点总是处于比较空闲的状态没有什么负载,就说明集群的负载出现不平衡,这个节点正在"挨饿"。事实上,这表明了集群节点的计算资源没有被充分的利用,负载均衡的作业分配效率很低。这是典型的负载均衡算法使用或者系统配置不当的问题;有的时候,没有充分考虑集群节点性能差异,采用"一视同仁"的分配算法也会引起挨饿。

举例来说,一个仅根据加权算法来分配的系统,节点很容易"挨饿":高权值的节点比其他节点更容易分配到任务,这就是为什么加权方法和其他方法要联合使用的原因。在节点处理能力非对称的集群中,能力强的节点处理请求更快,应答如果简单处理也很快,因此,在这种集群下最少连接法和最快响应法也可能导致节点"挨饿"(那些处理能力比较弱的节点总是分配不到任务)。比如,最快响应法受到平衡器和节点之间的网络连接影响,千兆以太网连接的节点比100兆标准以太网的响应速度自然快得多。

3. 网络不可达

网络不可达一般由于路由问题或者网络的暂时性错误引起的。他们对于访问者而言体现为一致的错误:"主机或网络不可达"。但是作为负载均衡器要有能力识别出其错误的区别,因为这将导致在集群管理上的差异。

  • 路由错误

    平衡器和节点之间、节点和用户之间会发生路由错误:错误的路由设置或者连接暂时断开,属于典型的管理配置错误。比如,负载平衡器的包转发模块向转发包插入错误的目的IP地址或者定义了非法的出口路由。平衡器应该能够发现断开的连接,并且反映出"没有到达主机的路由"。这样除非路由恢复,否则所有的负载算法都将失效。

    这一种错误对于WAN环境下的集群特别需要注意。作为系统管理员,有责任确保集群使用的远程通信线路是基本可靠。由于目前网格计算(Grid)日趋成熟,对于远程网络特别是骨干网络的核心部件要求也就更高。

  • 非自发的网络错误

    与上面的不同,这类错误是运行时网络的异常事件引起的。由于通信线路本身的瓶颈和故障,或者节点上的网络应用服务程序过载,导致应答数据丢失。这种临时错误由可能持续较长的时间,对最快响应法和拓扑定向法比较有影响。这也需要平衡器有能力监测出应用不可达和路由实效的区别。

    网络不可达错误在高可用集群环境中往往作为失效事件的触发条件,需要被被均衡器及时判断并做出响应。该错误比常见于网络风暴、节点web服务过载等情况下。由于内部通信机制的设计不当,导致节点之间过于频繁的进行消息通信,因而在集群内部的网络中产生大量的UDP通信包,使得网络阻塞。

    LVS的存储一致性问题:

    在一个通过LVS组建的Web集群环境中 ,所有涉及Session的应用都面临这样的矛盾:由于会话信息存储在服务结点上,因此一旦建立一次会话--例如登录bbs,之后的所有数据传输必须硬性的指向建立会话连接的节点(该Session以文件的形式保留在节点服务进程的路径下)。这样,会在调度算法上破坏原本正常运行的负载平衡。

    但是如果把所有的文件读写放在同一个磁盘上或者指向同一个NFS服务器,可以解决文件读写不一致的问题。但又导致新的问题出现:提供I/O服务的节点成为集群的性能瓶颈!

    怎么解决这一效率与功能之间的矛盾呢?可能的方式有:

    1、 改写Apache服务器,使之适应LVS的分布式环境

    2、 降低性能要求,使用NAS或者NFS服务进行磁盘共享

    3、 撰写特殊的PHP或者脚本语言代码

    4、 采用分布式文件系统

    例如,平衡器用于确认节点是否有效的心跳信号,就可能因为网络的阻塞而无法在Timeout时间内到达节点,因此这个本来正常的节点就会被平衡器认为是一个失效的节点从集群的有效节点列表中删除。

4. 存储一致性

对于一个集群系统而言,不可避免的要考虑系统中的数据存贮问题。一般来说,包括海量数据库系统和大规模电子邮局,一旦采用了分布式计算的构架,就一定要解决数据存储的容量和一致性两个方面的问题。

采用了分布式架构,海量存储自然变为可能。通过人工的方法或者预设的策略,可以将数据按照一定的单位分割(比如说块),分别存放在不同的物理存储设备上。典型的如大多数的数据库管理系统,借助文件组和跨磁盘存储能力,将大容量的数据信息存放在不同的磁盘分区,以提高整体的存储容量。像微软的Sql Server 中的文件组,或者是UDB2里面的TableSpace,可以跨磁盘分区存放表和其他数据库对象。

但是对于集群系统而言,尤其是网络负载平衡系统,集群内的节点被均衡器无差别地对待(就数据访问能力而言),均衡器假定所有的节点能够对同一数据进行一致读写。而同时出于容量的考虑又需要将数据分布式存储。那么如何保存各个节点的有效副本,如何对共享数据进行一致访问,就成为多数的负载平衡系统中至关重要的问题。

以目前比较流行的LVS(Linux Virtual Server)负载平衡系统为例。LVS通过linux的核心数据包投递程序,将进入集群系统的IP包按照既定规则转发到相应的集群节点进行处理。注意:这里处理的对象是网络数据包而不是具体的磁盘数据 ,那么意味着LVS假设所有的节点访问同一个一致的、可靠的、大容量的磁盘共享系统。当然,NAS或者共享RAID阵列等硬件上可以实现这一点,但是在兼顾效率和容量的分布式存储环境下,要求每一个节点保存部分数据,而且不同结点的数据互相不交叉或者交叉比较少。就难免出现数据读写不一致的情况。

而解决这类问题一般方法,要么是集中存储,使用共享的存储服务器或者存储设备;要么采用分布式文件系统,将文件分块存放在不同的节点磁盘上;再不然就是通过人工的手段对访问数据的应用程序进行改写,人为的设定程序的数据访问策略,在应用层实现分布式存储。各种方法都有有缺点:

方法一比较简单,找一台I/O处理能力强的服务器作为NFS服务器,提供唯一的数据存储入口即可解决,但是容易造成瓶颈;方法二兼顾了性能和容量,但是需要SAN这样的专有系统,实现复杂造价高;最后一种方法需要定制特定的应用层代码,大大增加了项目的开发成本和风险。

5. 均衡器单点失效

由于负载平衡集群的运转,完全依赖于均衡器的正常执行,而且多数集群对外体现的单一系统映像也必须通过均衡器这一角色来实现。因此,一旦均衡器失效,整个集群也就无法使用。提高集群的可用性,重点是解决核心部件的单点实效。

常见的方法就是冗余。这里通过一个特殊的"备份"节点,定期对均衡器进行监控,一旦发现均衡器无法正常访问,就立刻向所有的节点发出广播消息,告知错误,并且把均衡器上最近的有效数据加载到OS的内核,接管失效均衡器的任务。

监控的信息通过"心跳线路"传递,可以是专用的串口通信线路、红外设备,也可以是单独的局域网线,或者仅仅是逻辑上存在的信道。不管使用哪种连接,心跳信号的传递本身是要可靠的,而这一点只能依赖于监控机制和心跳线路的选择。

失效过后的替换过程不一而足,主要看均衡器是位于哪一层次上实现SSI(单一系统映像)。网络负载平衡集群中,均衡器一般都要承担一个虚拟IP管理者的角色。所以,备份节点在进行失效处理的时候,需要把虚拟IP地址接管过来,必要的话还需进行ARP响应欺骗的修改工作,告知路由器新的ARP映射列表。而更为常见的双机数据库热备份系统,需要处理数据库的名字替换工作,同时接管必要的在处理进程和联机事务操作。





回页首


一点思考

从上面的几点分析看来,集群的负载平衡诸多问题主要集中在:负载平衡机制的有效性、通信机制的效率、集群I/O的一致性等几个方面上。

一、集群能否在真正意义上对任务进行"平均分配"以实现负载平衡,其中最为关键的就是对节点当前状态信息的动态获取以及利用。实际上,理想的最优负载共享策略是很难实现的:

a) 在一个给定的时刻获得系统全局状态的精确信息是不可能的,由此引发分配算法的行为也是不稳定的。

b) 复杂分配算法和全局信息采集程序的执行可能会产生很大的系统开销。

c) 进程和数据迁移所带来的收益与开销比例难以准确估计。

由于上述的不可预测性,导致了在设计以及实现网络负载平衡集群时,尽量使用适合网络平衡条件的轮询或者最少连接算法,简单有效;并且,无论采用基于算法预测还是负反馈动态权值的机制,都要尽量避免通信包的泛滥。此外,在平衡算法和权值动态调整机制之间寻求一个合理的参数模型,需要在具体的集群中通过不断的试验来应证。

二、节点需要定时向均衡器报告当前负载状况,备份均衡器需要定时监听均衡器的心跳信号。这些需要都会导致频繁的通信在集群内发生。因此使用高效率的、可定制的网络消息协议就成了解决的关键。TCP/IP作为传统协议,本身存在一定的局限。设计开发一套适合的快速消息协议,可以从底层上解决大部分的通信效率问题。一般的思路是:在假定通信信道是可靠稳定的前提下,简化通信原语的设定,减少握手和确认消息,使用大的滑动窗口和收发缓冲区,甚至使用burst发送模式。关于消息通信的具体技术我们将在后续的篇章进行讨论。

三、对于数据一致存储的问题,现今比较成熟的技术有NAS和文件服务器。NAS其实是一种装有嵌入式系统的高效的文件服务器,一般提供大容量的可靠的磁盘存取服务,对外提供NFS的标准访问方式,兼容多数的OS。这样在集群中通过部署NAS实现集中存储保证节点的数据一致访问。但是改方法容易造成I/O瓶颈,不适合数据存取量比较大的集群系统。比较兼顾性能的做法有SAN系统,但是非常昂贵,在成本上救违背了集群的基本初衷。现在出现新的做法是在工作站部署分布式文件系统,利用节点本地磁盘组合全集群的大容量存储设备,即满足了容量的要求,在性能上又避免了传输瓶颈。比较好的有Lustre、GFS等。





回页首


结束语

集群的问题其实远远不只这些。我仅就一个网络负载平衡集群项目的实施,提供一些经验和个人观点。在后续的篇章中,将在一些专题上继续开展讨论,也算是目前这些问题的一个延伸。

分享到:
评论

相关推荐

    集群系统的可扩展性及其分布式体系结构

    本文档探讨了集群系统中的可扩展性问题及其分布式体系结构的设计与实现。文档指出,在当前信息技术快速发展背景下,集群技术作为提高系统性能、增强可靠性的有效手段,越来越受到人们的重视。特别是在Linux环境下,...

    高可用分布式架构设计与实践-内训方案.pdf

    无共享架构是一种设计模式,其目的是通过减少不同节点间的共享状态来提高系统的可扩展性和可用性。这种架构下,每个节点都是独立的,并且可以独立地进行扩展或故障恢复。 #### 第二课:总体架构篇 - **空间换时间...

    linux集群体系结构

    Linux集群体系结构是一种高效、可扩展且高可用的计算架构,它通过将多个独立的Linux服务器连接在一起,形成一个统一的资源池,从而提供比单个服务器更高的性能和可靠性。这种技术广泛应用于大规模数据处理、高并发...

    基于MapReduce的分布式ETL体系结构研究.pdf

    MDETL体系结构在保持分布式ETL灵活性和吞吐率的同时,通过分布式执行ETL流程,实现了系统的可扩展性和负载平衡性能的提升。该体系结构还降低了硬件成本,提高了ETL执行效率的稳定性和高效性,进而实现了分布式ETL的...

    Google集群体系结构分析.pdf

    相比于其他体系结构系统,Google集群系统在成本效益、可扩展性和维护性方面具有显著优势。然而,它也存在一些局限性,比如在处理特定类型的工作负载时可能不如定制化的高性能计算集群。 #### 八、结论 Google集群...

    分布式集群技术.pdf

    这种技术可以提高系统的可扩展性、可靠性和性能。 Linux 操作系统是分布式集群技术的基础,Linux 的发展历史、Linux 和 Windows 的对比和优势、Linux 的常见版本等内容将为读者提供了 Linux 的基础知识。 Linux 的...

    腾讯社交网络分布式数据运维之道

    腾讯社交网络平台在数据存储方面采用了分布式NoSQL集群架构,以应对大数据量、高并发、快速迭代的业务场景。...这些都是构建和维护现代社交网络平台高性能、高可用性分布式存储系统不可或缺的知识和经验。

    试论分布式区域教育教学资源中心网络架构的研究与设计.pdf

    IP-SAN技术则通过FCIP和iFCP等技术实现了IP环境下的SAN互连,使传统SAN的限制得到解除,大大增强了网络异构储存系统的可扩展性和高性能。 在研究分布式区域教育教学资源中心网络架构的设计时,还需要考虑到各种网络...

    学习资料_linux_集群

    本学习资料包专注于Linux集群的相关知识,包括集群系统的可扩展性、分布式体系结构以及相关工具的使用。 1. **集群系统的可扩展性**: 集群系统的可扩展性是指通过添加更多的硬件资源(如服务器和存储)来提升系统...

    分布式计算

    - **云计算**:提供可扩展的计算资源和服务,用户可以通过互联网按需获取所需的服务。云计算分为**公有云**和**私有云**两种模式。公有云面向广泛用户群体提供服务,而私有云则为特定组织内部使用。 #### 三、...

    基于FastCGI的分布式集群WebGIS研究.pdf

    性能测试和实际项目验证表明,基于FastCGI的多进程、分布式集群构建的WebGIS系统相比其他模式的WebGIS具有更高的效率、更强的可扩展性和更好的稳定性。这些特点是通过减少单点故障、提高并发处理能力、以及增强系统...

    基于集群路由器体系结构的BGP分布并行实现技术研究.pdf

    相对于传统的集中控制方式,分布式实现技术具有更好的可扩展性、更高的处理能力和更低的延迟,更能适应大规模网络环境的需求。 在实际应用中,选择哪种实现技术取决于具体网络环境、设备资源以及性能需求。通常,...

    含泪总结分布式书上所有考点.docx

    分布式计算的关键目标包括资源可访问性、透明性、开放性和可扩展性。透明性涉及访问透明性、位置透明性、并发透明性、复制透明性、故障透明性和移动透明性,这些都旨在让用户和应用程序能够无缝地与分布式系统交互,...

    集群、高性能计算的基础学习资料

    此外,“集群系统的可扩展性及其分布式体系结构.pdf”和“Looking Back over 15 Years of Supercomputing Experience.PDF”这两篇文献将深入探讨集群的可扩展性和分布式架构的设计,以及过去十五年超级计算的实践...

    分布式架构说明

    - **架构概述**:分布式系统的核心在于利用微服务技术,并结合分布式数据库、弹性容器管理、消息中间件和分布式缓存等技术,构建一个高度可扩展且可用性强的系统。这种架构能够有效地应对大规模并发请求,保证系统的...

    《分布式系统原理与范型》答案

    实现可扩展性的常见技术包括: - **分布式架构**:通过分散处理负载来提升性能。 - **复制**:通过复制关键数据或服务来提高可靠性和响应速度。 - **缓存**:减少对后端系统的访问频率,提高响应速度。 #### 七、...

    网络游戏-多参与者游戏体系结构.zip

    9. **扩展性**:为了适应未来增长,游戏架构需要具有良好的可扩展性,能够轻松添加新功能或升级硬件。 10. **分布式系统设计**:对于大型的多参与者游戏,可能需要分布式服务来处理特定任务,如分布式计费系统、...

Global site tag (gtag.js) - Google Analytics