负载均衡详解
一、负载均衡
在互联网场景下,负载均衡(Load Balancing)是分布式系统架构设计中必须考虑的一个环节,它通常是指将负载流量(工作任务、访问请求)平衡、分摊到多个操作单元(服务器、组件)上去执行的过程,目的在于提供负载配比,解决性能、单点故障(高可用)和扩展性(水平伸缩)等问题。
随着互联网的兴盛,类似淘宝、京东等网站的访问量逐年提升,原先的单台服务或者单集群模式已经远不能满足需求了,这时候就需要横向扩展多台服务或者多个集群来分摊压力,达到提升系统吞吐的能力,这就是著名的分治理论,但服务器增加了,他们之间的流量负载也必须有一个组件来管控,这就是负载均衡的作用。
二、负载均衡策略
负载均衡提供了多种算法策略来满足不同的业务负载需求,以下是几种常见的负载均衡策略:
1、轮询(Round Robin)
描述:按照请求的顺序轮流分配到不同的服务器,循环往复,这种策略适用于服务器性能相近的情况,可以平均分配负载,但如果某个服务器性能较差或者偶发故障,会影响整个系统的性能和稳定性。
示例:分别有5条请求过来,按照顺序轮流分配,web-server1 分配到 1、4,web-server2 分配到 2、5,web-server3 分配到 3。
2、加权轮询(Weighted Round Robin)
描述:给不同的服务器分配不同的权重,根据权重比例来决定分配请求的数量,这种策略适用于后端服务器性能不均的情况,可以根据实际情况灵活调整,使得性能更好的服务器能够处理更多的请求,从而提高整个系统的处理效率。
示例:分别有5条请求过来,web-server1 因为权重为60%,分配到 1、2、3;web-server2 权重为20%,分配到 4;web-server3 权重为20%,分配到 5。
3、IP 哈希(IP Hash)
描述:根据客户端的IP地址计算哈希值,将请求分配给特定的服务器,保证相同IP的客户端请求始终发送到同一台服务器,这种策略适用于需要保持客户端会话一致性的场景,例如需要维护用户session的Web应用。
示例:IP为192.168.0.99的流量hash计算对应web-service1,所以将1、4流量分配到第1台服务器;IP为192.168.0.96、192.168.0.98的流量hash计算对应web-service3,所以将2、3流量分配到第1台服务器,需要注意的是,虽然IP哈希算法可以确保来自同一IP地址的请求被发送到同一台服务器,这在一些需要保持会话一致性的场景中很有用,但它也可能导致负载不均衡,如果某个IP地址发送了大量的请求,那么处理这些请求的服务器可能会过载,而其他服务器可能处于空闲状态,在使用IP哈希算法时,需要仔细考虑其适用性和潜在的风险,需要对极端情况进行评估,笔者就曾经踩过坑。
4、最少连接(Least Connections)
描述:将请求分配给当前连接数最少的服务器,以实现负载均衡,这种策略适用于处理长连接请求的场景,如WebSocket、FTP服务,通过记录每台服务器当前正在处理的连接数,将新请求分配给连接数最少的服务器,可以有效避免某些服务器过载导致性能下降的情况。
示例:web-service1、web-service2、web-service3的连接数分别是11、15、2,web-service3 相对空闲,1、2、3请求到来的时候,web-service3持续空闲,而web-service1、web-service2持续hold住连接,所以请求分配给web-service3,该算法对服务器性能差异较大的情况有较好的适应性,请求优先发送到连接数较少的服务器,有助于避免某些服务器过载,提升性能,缺少点就是需要实时监测连接数,并且每个流量来的时候都要判断下再分发,在流量繁忙时增加了服务器开销,影响性能。
5、最短响应时间(Least Response Time)
描述:短响应时间(Least Response Time)算法在负载均衡领域中被广泛应用,这种策略适用于对响应时间有严格要求的应用场景,通过实时监测每台服务器的响应时间,将请求分配给响应时间最短的服务器,可以确保用户获得最快的响应,提升用户体验。
示例:同样,这种算法也有自己的优缺点:提高用户体验:通过选择响应时间最短的服务器来处理请求,可以显著减少用户的等待时间,提高整体的用户体验,动态负载均衡:该算法能够实时地根据服务器的响应时间来调整负载分配,确保每台服务器都能根据其实际性能来处理相应数量的请求,处理高峰期流量:在流量高峰期,最短响应时间算法可以确保请求被迅速处理,避免系统拥堵和延迟,计算开销:为了确定每台服务器的响应时间,系统需要不断地进行监测和计算,这可能会增加额外的系统开销,瞬时波动:由于该算法主要依赖于实时的响应时间,因此可能会受到瞬时波动的影响,如果某台服务器在某一时刻由于某种原因(如临时的高负载)响应时间变长,它可能会被暂时排除在负载均衡之外,即使其实际性能可能仍然优于其他服务器,可能忽略其他性能指标:最短响应时间算法主要关注响应时间,可能忽略了其他重要的性能指标,如服务器的处理能力、内存占用等,在某些情况下,这可能导致负载分配不够均衡。
三、负载均衡分类
从软硬件的角度来看,负载均衡可以分为硬件负载均衡和软件负载均衡。
1、硬件负载均衡器:是专为负载均衡任务设计的物理设备,它利用专用硬件组件(如ASICs或FPGAs)来高效分发流量,其优点在于高性能和吞吐量,经过优化的任务处理,以及内置网络安全、监控和管理功能,能应对大量流量和多种协议,硬件负载均衡器通常价格昂贵,特别是高性能型号,配置和维护也需要专业知识,且可扩展性受限。
2、软件负载均衡器:则是运行在通用服务器或虚拟机上的应用程序,使用软件算法将流量分发到多个服务器或资源,其优点在于经济实惠、适应性强、易于扩展(可通过增加资源或升级硬件实现)以及灵活(可在各种平台和环境中部署),但在高负载下,软件负载均衡器的性能可能较差,且可能影响主机系统资源,需要维护软件更新。
根据分配策略的不同,负载均衡还可以分为普通负载均衡和动态负载均衡,普通负载均衡是指将用户请求均匀地分发到多个服务器,以实现服务器的负载均衡,通常采用静态的分发算法,如轮询、随机等,而动态负载均衡则是根据服务器的实时负载情况,动态地调整请求的分发策略,以保证服务器负载的均衡,每个服务器被分配一个权重值,权重越高,则分发到该服务器的请求越多。
四、负载均衡部署方式
在负载均衡的部署中,还需要考虑其网络架构,常见的负载均衡部署模式包括:
1、路由模式:服务器的网关必须设置成负载均衡机的LAN口地址,且与WAN口分署不同的逻辑网络,这种方式对网络的改动小,能均衡任何下行流量,约60%的用户采用这种方式部署。
2、桥接模式:负载均衡器的WAN口和LAN口分别连接上行设备和下行服务器,所有的服务器与负载均衡均在同一逻辑网络中,此模式配置简单,不改变现有网络,但由于容错性差,一般不推荐。
3、服务直接返回模式:负载均衡器的LAN口不使用,WAN口与服务器在同一个网络中,对于客户端而言,响应的IP是服务器自身的IP地址,返回的流量不经过负载均衡,这种模式比较适合吞吐量大特别是内容分发的网络应用,约30%的用户采用这种模式。
五、负载均衡工具
常用的软件负载均衡软件有 Nginx、LVS、HAProxy 等,Nginx/LVS/HAProxy 是目前使用最广泛的三种负载均衡软件,LVS(Linux Virtual Server),主要是用四层来做负载均衡,Nginx 主要是做七层负载均衡。
小伙伴们,上文介绍了“负载均衡等方面”的内容,你了解清楚吗?希望对你有所帮助,任何问题可以给我留言,让我们下期再见吧。
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/1314200.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复