负载均衡及负载均衡器

640?wx_fmt=png

负载均衡

在分布式系统中,负载均衡(load balancing)是一种有效的将网络请求分配到多个服务器的过程。通过将负载进行负载均衡,可以有效地改进系统响应时间,提高系统的可用性。随着系统变的愈发复杂,用户增多和网络流量增大,负载均衡已经成为系统设计中的必要一环。

负载均衡是对应用服务器架构进行水平扩展(scale out)的最为直接的方法。当系统面对用户增多、并发请求增多的状况时,我们可以直接向系统中添加更多的服务器进行水平扩展,负载均衡器会马上开始向新的服务器发送一部分用户请求,从而达到系统的水平扩展,使得每个服务器会有几乎数量相同的客户请求。

实现负载均衡最主要有两个目的。一是使得每个服务器有相同的负载,以减少单个服务器的负载,从而可以达到我们上面提到的对系统进行水平扩展的目的。二是提高系统容错能力,从而达到高可用的目的。在分布式系统中,多个服务器往往会提供相同的服务,所以当一个服务器宕机时,我们可以通过负载均衡器(load balancer)将该服务器对应的负载转发到其他机器上,从而提高系统的可用性。如果没有负载均衡器,我们只是将对应的负载直接转发到某几个机器,那么如果那几个机器本身就有了很高的负载,面临突然的大量负载,有可能会造成其他机器的宕机。

负载均衡器

负载均衡器可以是硬件也可以是软件,它会将网络请求分发到服务器集群上。在下图中,负载均衡器处于客户端和服务器之间,将客户端请求转发到不同的后端服务器来完成客户端请求。通过将客户端请求平均的分发到后端服务器,负载均衡器有效的减少服务器请求,避免了某个服务器会单点失败。

640?wx_fmt=png

我们可以将负载均衡器的特点总结如下:

  • 如果单个服务器宕机,负载均衡器会移除该服务器,并将请求转发到其他在线服务器

  • 当一个新服务器被添加到集群中,负载均衡器会自动开始向它发送请求

  • 有效的将客户端请求或者网络负载分发到多个服务器上

  • 因为只向在线的服务器发送请求从而确保了高可用和可靠性

  • 提供了按需增减服务器的灵活性,并不会影响到已有的服务器上的连接

  • 可以被应用到不同的层次中,比如服务器,数据库或者缓存

负载均衡器是基于如下两个步骤来为一个客户端请求选择对应的后端服务器的。首先,确认服务器是否可用。然后根据配置好的负载均衡算法从这些健康的服务器中选择一个服务器。

健康检查(Health Check): 为了确保负载均衡器只将请求发送给健康的服务器,健康检查会周期性尝试连接后端服务器,确保服务器在监听。如果一个服务器健康检查失败了,该服务器会被自动从服务器集群中移除,客户端请求将不会被转发到该服务器上,直到该服务器开始对健康检查开始进行响应。

负载均衡算法

  • 轮询调度算法(Round Robin) 

    该算法会依次将请求派发到健康服务器列表中的每一台服务器上。比如健康服务器列表为A,B,C,D。请求就会按此顺序被分发到上面。

  • 最少连接算法(Least Connections) 

    该算法会查看集群中哪一个服务器有最少的连接,然后将请求发送到具有最少连接数目的服务器上

  • 最少响应时间(Least Response Time)

        该算法会将请求转发到具有最少连接并且最低平均响应时间的服务器上

  • 最小带宽算法(Least Bandwidth Method) 

    该方法会将请求转发到有最小流量的服务器上,这里流量以Mbps来测量

  • IP地址哈希(IP Hash) 

    该算法根据IP地址来决定将请求转发到哪个服务器上

  • 粘滞会话(Sticky Session Scheme)

    根据请求的依赖关系将请求转发到正确服务器上。比如用户的购买请求依赖于用户登录请求,当负载均衡器收到用户的购买请求时,它会将其转发到对应的处理登录请求的服务器上,否则将会报错。

  • 均匀任务队列派发(Even Size Task Queue Distribution Scheme) 

    每个服务器用一个队列存储收到的请求,如果服务器处理请求的速度快,那么队列里请求数目减少的也快,那么负载均衡器只需要根据队列中的数目,将请求放到最小数目的队列中即可。

负载均衡器的能力

L4负载均衡器: 基于传输层协议例如IP地址和TCP端口对请求进行转发

L7负载均衡器: 基于应用层数据和属性进行请求转发,比如http包头,统一资源定位符(URI),SSL会话ID和HTML表格数据

全局服务器负载均衡器: 对L4和L7进行扩展,使得负载均衡器可以对全局的服务器进行负载均衡

常用负载均衡器

负载均衡器已经有了很多的解决方案。比如,硬件方面有F5,A10,软件方面有Nginx,HAProxy,LVS。如果整个系统是云架构,那么云厂商也提供了成熟的负载均衡选择比如Azure负载均衡器和AWS负载均衡器。硬件负载均衡器往往具有难以扩展(因为需要额外增加硬件),成本贵(购买硬件,专业人员安装维护)和安全性(物理硬件自身设计导致)等缺点。软件负载均衡器消除了硬件负载均衡器的这些缺点,并具有按需进行调节的灵活性和易于和系统进行集成。因此,我们在面对系统进行水平扩容的时候不妨先考虑开源的软件负载均衡器,如果确实有满足不了的地方,再考虑重复造轮子。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/313935.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VS Code 摸鱼插件开发小记

插件地址:https://marketplace.visualstudio.com/items?itemNamebugbreeder.vscode-readhub原文链接:https://github.com/alex-yh99/vscode-readhub/blob/master/docs/develop-note.md一、关于插件在 VSCode 中快捷查阅科技动态、开发者资讯等 Readhub …

9月数据库排行:Microsoft SQL Server分数罕见下滑

DB-Engines 数据库流行度排行榜 9 月更新已发布,排名前二十如下:明显能看出来,整体排名和上个月的保持一致。而上个月出现分数下跌的 PostgreSQL 和 MongoDB 终于“回归正道”,分数有了稍微的上升。与上个月相比,Postg…

Exceptionless使用介绍

一.Exceptionless介绍Exceptionless专注于.net平台提供实时错误和日志报告。主要包括:错误通知、智能分组异常、详细错误报告堆栈跟踪、支持离线、UI查看重要错误和确定优先级、仪表板上的统计信息和趋势、对异常标记为已修复,监视回归、将事件标记为关键…

Net Core DocXCore 实现word模板导出

实际工作中,往往有这样的需求,需要导出word,还有各种各样的样式,于是有了word模板导出。实现以下几个需求:1、表单导出2、表格导出3、表单表格混合导出4、实际用例测试解决方案:实现是基于NET Core 2.1 &am…

密钥分离,.Net程序猿不再背锅

引言互联网每隔一段时间就会爆出 【某程序猿在代码托管平台上传了公司机密配置信息,导致公司核心数据被黑客获取或修改】, 一茬又一茬背锅侠层出不穷。拯救自我软件工程理论早以加粗字体给出 经典原则:Never store production passwords or o…

Chrome让人失望,是时候转到Firefox或Edge?

我们曾报道过谷歌正在移除 Chrome 的关闭其他选项卡,这引起很多用户的讨论,很多用户表现出对 Chrome 浏览器的失望。而在国外,也有很多人认为谷歌这项修改使 Chrome 变得越来越臃肿。还有前段时间,谷歌在 Chrome 76 中隐藏了 “ht…

我认真写下9段如翔一般的代码,只为等你来品鉴

溪源 | 长沙.NET技术社区开篇我们总是很容易就能写出满足某个特定功能的代码,却很难写出优雅代码。又最欣赏那些优雅的代码,因为优雅代码更能体现一个开发者的积累。就像写一篇散文,有的就像初学者不得其门而入,遣词造句都非常困难…

「标签管理」用数据管理思维去管理你的日常电子化资料、文件、笔记等

最近一时兴起,研究了一些文件管理的方法论和笔记管理类的知识,自己想到一些不错的方法及落地方案,可能对一部分朋友来说,这些方法和工具的落地会有一些共鸣,故简单给大家做一下分享。跨界应用:数据表结构应…

Java之JMS

一:JMS简介   JMS即Java消息服务(Java Message Service),是一个Java平台定义的关于面向消息中间件的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。JMS是一个与具体平台无…

程序员过关斩将--更加优雅的Token认证方式JWT

点击上方“蓝字”带你去看小星星菜菜,上次你讲的cookie和session认证方式,我这次面试果然遇到了结果怎么样?结果面试官问我还有没有更好的方式?看来你又挂了别说了,伤心呀。到底还有没有更好的方式呢?你猜&…

Java之JMX

JMX,即Java Management Extensions,Java管理扩展。是一个为应用程序、设备、系统等植入管理功能的框架。   JMX提供了一种简单、基础的方法,用来管理应用、设置、服务等资源。由于JMX是动态的,你可以使用JMX技术来监控和管理处于…

[NewLife.XCode]分表分库(百亿级大数据存储)

NewLife.XCode是一个有15年历史的开源数据中间件,支持netcore/net45/net40,由新生命团队(2002~2019)开发完成并维护至今,以下简称XCode。整个系列教程会大量结合示例代码和运行日志来进行深入分析,蕴含多年开发经验于其中&#xf…

你的技术债还了吗?

什么是技术债?技术债是由沃德坎宁安在1992年提出,指我们在软件架构或代码编写过程中有意无意地做了错误的决策。随着时间的累积,这种错误会越来越多,就像背负了很多债务一样。技术债的危害技术债同财务债一样,是有利息…

拿 C# 搞函数式编程

最近闲下来了&#xff0c;准备出一个 C# 搞 FP 的合集。本合集所有代码均以 C# 8 为示例。可能你说&#xff0c;为什么要这么做呢&#xff1f;回答&#xff1a;为了好玩。另外&#xff0c;意义党们请 gun cu ke&#xff01;C# 有委托&#xff0c;而且有 Func<> 和 Action…

CNCF发布K8s项目历程报告,35k贡献者有你吗?

云原生计算基金会 CNCF 首次发布了 Kubernetes 项目历程报告。Kubernetes 托管于 CNCF&#xff0c;它是目前使用最广泛的容器编排平台&#xff0c;通常被称为“云端 Linux”&#xff0c;CNCF 介绍此报告旨在客观地评估 Kubernetes 项目的状态以及 CNCF 如何影响 Kubernetes 的发…

API 和 SPI

简介&#xff1a; API&#xff1a;Application Programming Interface应用程序接口 SPI&#xff1a;Service Provider Interface服务商提供接口 JDK中有描述&#xff0c; the API is the description of classes/interfaces/methods/… that you call and use to achieve a go…

编程语言这一年

最近开源中国&#xff08;OSCHINA&#xff09;在庆祝 11 周年生日&#xff0c;编辑部借着这个机会梳理了一下这一年来我们追过的那些开源界/开发界的热点新闻&#xff0c;算作一个阶段性小结。&#xff08;其实只有 9 个月&#xff5e;&#xff09;开源中国是目前国内为数不多深…

使用Elastic APM监控你的.NET Core应用

前言在应用实际的运维过程中&#xff0c;我们需要更多的日志和监控来让我们对自己的应用程序的运行状况有一个全方位的了解。然而对于大部分开发者而言&#xff0c;平时大家所关注的更多的是如何更优雅的实现业务&#xff0c;或者是如何让应用的响应速度更快等等与编码相关的技…

ASP.NET Core结合Nacos来完成配置管理和服务发现

前言今年4月份的时候&#xff0c;和平台组的同事一起调研了一下Nacos&#xff0c;也就在那个时候写了.net core版本的非官方版的SDK。虽然公司内部由于某些原因最后没有真正的用起来&#xff0c;但很多人还是挺看好的。在和镇汐大大沟通后&#xff0c;决定写一篇博客简单介绍一…

Java 时间处理

时区、冬令时和夏令时、时间戳 时间戳 距离一个标准参照时间经过的秒数&#xff08;毫秒数&#xff09; 有两个常用参照时间&#xff1a; 1970-01-01 00:00:00 应用最广泛的时间戳参照点2001-01-01 00:00:00 常被苹果系统使用 注意&#xff1a;以上时间节点皆采用UTC的标准时…