什么是负载均衡

这篇具有很好参考价值的文章主要介绍了什么是负载均衡。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前提概述

         关于负载均衡,我会从四个方面去说

1. 负载均衡产生的背景

2. 负载均衡的实现技术

3. 负载均衡的作用范围

4. 负载均衡的常用算法


负载均衡的诞生背景

        在互联网发展早期,由于用户量较少、业务需求也比较简单。对于软件应用,我们只需要一台高配的服务器即可完成业务的支撑,这样的软件架构称为单体架构。

        什么是负载均衡,Java,负载均衡

 

        随着用户量的增加,服务器的请流量也随之增加,在这个过程中单体架构会产生两个问题。

        1. 软件的性能逐步下降,访问延迟越来越高

        2. 容易出现单点故障

        为了解决这个问题,我们引入了集群化部署的架构,也就是把一个软件应用同时部署在多个服务器上。

什么是负载均衡,Java,负载均衡

        架构的变化带来了两个问题:

                1. 客户端请求如何均匀的分发到多台目标服务器上?

                2. 如何检测目标服务器的健康状态,使得客户端请求不向已经宕机的服务器发送请求。

        

        为了解决这两个问题,引入了负载均衡的设计,简单来说,负载均衡机制的核心目的是让客户端的请求合理均匀的分发到多台目标服务器,由于请求被多个节点分发,使得服务端的性能得到有效的提升。


如何实现负载均衡呢?

常见的实现方案有三种:

         基于 DNS 实现负载均衡

         基于硬件实现负载均衡

         基于软件实现负载均衡

        先来说一下基于 DNS 实现负载均衡的方式,它的实现方式比较简单,只需要在 DNS 服务器上针对某个域名做多个 IP 映射即可。

什么是负载均衡,Java,负载均衡

         它的工作原理是:当用户通过域名访问某个网站时,会先通过 DNS 服务器进行域名解析得到一个 IP 地址,DNS 服务器可以随机分配一个 IP 地址进行访问,这样就可以实现目标服务集群的请求分发。

         除此之外,DNS 还可以根据不同的地域分配就近机房的 IP,比如长沙的小伙伴,可能得到在湖南范围内最近的一个机房的 IP,在这个模式下可以实现「就近原则」实现请求处理,缩短了通信距离从而提升网站访问效率。

         DNS 实现负载均衡的优点是: 配置简单,实现成本低,无需额外的开发和维护。

不过缺点也很明显:由于 DNS 多级缓存的特性,当我们修改 DNS 配置之后,会因为缓存导致 IP 变更不及时,从而影响负载均衡的效果。

       


         第二种,基于硬件实现负载均衡

        硬件负载设备,我们可以简单把它理解成一个网络设备,类似于网络交换机,

                1、它的性能很好,每秒能够处理百万级别的请求

                2、支持多种负载均衡算法,我们可以非常灵活的配置不同的负载策略

                3、它还具备防火墙等安全功能

                4、硬件负载是商业产品,有专门的售后来支持,所以企业不需要花精力去做维护。

        F5 是比较常见的硬件负载设备,由于硬件负载设备价格比较贵,一般应用在大型银行、 政府、电信等领域。


        第三种,基于软件实现负载均衡。所谓软件负载,就是通过一些开源软件或者商业软件来完成负载均衡的功能。常见的软件负载技术有:Nginx、LVS、HAProxy 等。

        目前互联网企业绝大部分采用的都是软件负载,主要原因是:

                1. 免费,企业不需要投入较高的成本。

                2. 开源,不同企业对于负载均衡的要求有差异,所以可以基于开源软件上做二次开发。                 3. 灵活性较高

        这三种方式,没有好坏之分,只有是否合适,因此大家可以根据实际情况选择。


负载均衡的作用范围

        负载均衡是作用在网络通信上,来实现请求的分发。 而在网络架构中,基于 OSI 模型,又分为 7 层网络模型

什么是负载均衡,Java,负载均衡

        也就是意味着我们可以在网络的某些分层上做请求分发处理,因此根据这样一个特性, 对于负载均衡的作用范围又可以分为:

    1、二层负载

    2、三层负载

    3、四层负载

    4、七层负载

        二层负载:基于 Mac 地址来实现请求分发,一般采用虚拟 Mac 的方式实现,服务器收到请求后,通过动态分配后端服务的实际 Mac 地址进行响应从而实现负载均衡。

        三层负载:基于 IP 层负载,一般通过虚拟 IP 的方式实现,外部请求访问虚拟 IP,服务器收到请求后根据后端实际 IP 地址进行转发。

        四层负载:通过请求报文中的目标地址和端口进行负载,Nginx、F5、LVS 等都可以实现四层负载。

        什么是负载均衡,Java,负载均衡

        七层负载:七层负载是基于应用层负载,也就是服务器端可以根据 http 协议中请求的报文信息来决定把请求分发到哪个目标服务器上,比如 Cookie、消息体、 RequestHeader 等。


负载均衡的常用算法

        所谓负载均衡算法,就是决定当前客户端请求匹配到目标服务器集群中的具体哪个节点。

 常见的负载均衡算法有:

    1. 轮训,也就是多个服务器按照顺序轮训返回,这样每个服务器都能获得相同的请求次数

什么是负载均衡,Java,负载均衡

         2. 随机,根据随机算法获得一个目标服务地址(就像古时候皇帝翻牌子),由于该算法具备随机性,因此每个服务器获得的请求数量不一定均等。

        3. 一致性 hash,也就是对于具有相同 hash 码的请求,永远发送到同一个节点上。

        4. 最小连接数,根据目标服务器的请求数量来决定请求分发的权重,也就是目标服务集群中,请求更少的节点将会获得更多的请求。这是负载均衡中比较好的策略,真正能够实现目标服务器的请求均衡。

 


        以上就是关于负载均衡相关的内容,当然,负载均衡还有很多值得去挖掘的,比如负载算法如何实现?网络分层模型的原理等等。

  文章来源地址https://www.toymoban.com/news/detail-667435.html

到了这里,关于什么是负载均衡的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • H3C交换机端口静态聚合 流量是按负载均衡还是什么工作模式

    H3C交换机 H3C交换机端口静态聚合 流量是按负载均衡还是什么工作模式 在 H3C 交换机上,您通常可以使用以下命令查看当前的负载均衡模式: 这个命令会显示系统中所有聚合链路或指定聚合链路的负载均衡模式。如果您想要更改默认的负载均衡模式,可以使用类似下面的命令

    2024年03月12日
    浏览(48)
  • 【Java】微服务——Ribbon负载均衡(跟进源码分析原理)

    添加@LoadBalanced注解,即可实现负载均衡功能,这是什么原理 SpringCloud底层其实是利用了一个名为Ribbon的组件,来实现负载均衡功能的。 为什么我们只输入了service名称就可以访问了呢?之前还要获取ip和端口。 显然有人帮我们根据service名称,获取到了服务实例的ip和端口。它

    2024年02月07日
    浏览(41)
  • 【java苍穹外卖项目实战三】nginx反向代理和负载均衡

    我们思考一个问题: 前端发送的请求,是如何请求到后端服务的? 前端请求地址:http://localhost/api/employee/login 后端接口地址:http://localhost:8080/admin/employee/login 很明显,两个地址不一致,那是如何请求到后端服务的呢? 1、nginx反向代理 nginx 反向代理 ,就是将前端发送的动态

    2024年02月21日
    浏览(49)
  • Java后端入职第六天,Nginx搭建负载均衡+反向代理

    Nginx相信大家应该不陌生吧!是一个高性能web服务器,可以做负载均衡或者是反向代理,比如,把静态页面直接部署到到html,实现动静分离,一个服务器部署多个服务,缓解服务压力,等等,都可以利用Nginx实现。 这个理解比较简单,其实就是压力分摊,一个工程部署多个节

    2024年02月08日
    浏览(66)
  • Java实习面试经验汇总,Dubbo-负载均衡原理解析,TCP的三次握手、四次挥手

    if (sameWeight i 0 !weight.equals(weights[i - 1])) { sameWeight = false; } } Integer sequenceNum = Sequence.getAndIncrement(); Integer offset = sequenceNum % totalWeight; offset = offset == 0 ? totalWeight : offset; if (!sameWeight) { for (String ip : ServerIps.WEIGHT_LIST.keySet()) { Integer weight = ServerIps.WEIGHT_LIST.get(ip); if (offset = weight) { ret

    2024年04月25日
    浏览(40)
  • 【kafka】Java客户端代码demo:自动异步提交、手动同步提交及提交颗粒度、动态负载均衡

    kafka版本为3.6,部署在3台linux上。 maven依赖如下: 生产者、消费者和topic代码如下: 这里先简单解释一下, kafka的topic只是一个逻辑上的概念,实际上的物理存储是依赖分布在broker中的分区partition来完成的 。kafka依赖的zk中有一个 __consumer_offsets [1]话题,存储了所有consumer和g

    2024年01月19日
    浏览(55)
  • 基于grpc-java开发的普通工程在k8s内部署多实例,如何实现客户端流量的负载均衡

    本文主要讨论通过grpc-java开发的普通的java grpc工程,以多实例的方式部署在容器编排平台kubernetes(以下简称k8s)上,如何能够实现让同样部署在k8s 集群内的客户端请求流量均衡的分发到多个grpc应用部署实例上去。 grpc服务端程序在k8s内部署的多个实例通过headless service暴露服

    2024年01月17日
    浏览(51)
  • SpringCloud(3) Ribbon负载均衡,负载均衡策略,自定义负载均衡

    假设我们有一台 order-service 订单服务,两台 user-service 用户服务,当订单服务需要调用用户服务获取用户信息的时候,应该怎么分配调用哪台服务呢? 这时候就需要用到 Ribbon 组件了。 首先,我们发起远程调用的时候,指定的是需要调用的服务名称,然后我们会调用 Ribbon 组

    2024年02月11日
    浏览(46)
  • 【负载均衡】常见的负载均衡策略有哪些?

    负载均衡策略是实现负载均衡器的关键,而负载均衡器又是分布式系统中不可或缺的重要组件。使用它有助于提高系统的整体性能、可用性、可靠性和安全性,同时支持系统的扩展和故障容忍性。对于处理大量请求的应用程序和微服务架构来说,负载均衡器是不可或缺的重要

    2024年02月09日
    浏览(41)
  • LVS负载均衡(web网站负载均衡)

        一、概述         功能强大         转发策略比较多         适合大型的网络高可用      二、作用         使用keepalived解决lvs的单点故障高可用集群      三、环境         1.准备6台虚拟机,2台做LVS主备调度器,2台做web服务器,1台做存储,1台客户机验证

    2024年02月09日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包