热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

详谈负载均衡(微服务架构下的高可用挑战)

文章目录一、互联网架构发展历程二、集中式LB服务发现三、进程内LB服务发现四、独立LB进程服务发现五、负载均衡(1)DNS负载均衡(2&#


文章目录

    • 一、互联网架构发展历程
    • 二、集中式LB服务发现
    • 三、进程内LB服务发现
    • 四、独立LB进程服务发现
    • 五、负载均衡
        • (1)DNS负载均衡
        • (2)负载均衡技术(类比LVS)
            • 【1】NAT(网络地址转换)
            • 【2】新建TCP连接(NAT的优化)
            • 【3】DR(直接路由,链路层负载均衡)
            • 【4】TUN(隧道技术)



服务发现:


  • 微服务架构是由一系列职责单一的细粒度服务构成的分布式网络结构,服务之间通过轻量级机制进行通信,这时候必然会引入一个服务注册发现问题,也就是说服务提供房需要注册通过服务地址,服务的调用方要能发现目标服务。
  • 同时服务提供方一般会以集群的方式提供服务,也就引入了负载均衡和健康检查的问题。

一、互联网架构发展历程

在这里插入图片描述


二、集中式LB服务发现


  • 在服务消费者和服务提供者之间有一个独立的LB
  • LB上所有的服务的地址的映射表,通常由运维配置注册
  • 当服务消费方调用某个目标服务的时候,它向LB发起请求,由LB以某个策略做负载均衡后将请求转发到目标服务
  • LB一般具有健康检查能力,能自动摘除不健康的实例
  • 服务消费方通过DNS找到LB
  • 集中式主要存在的问题是存在单点故障,所有流量都走LB,LB很容易成为瓶颈
    在这里插入图片描述

三、进程内LB服务发现


  • 进程内LB方案将LB的功能以库的形式集成到服务消费方的进程里
  • 服务注册表配合支持服务的自注册和自发现,服务提供方启动时,首先将服务地址注册到服务注册表(同时定期报心跳以表明服务的存活状态)
  • 服务消费方要访问某个服务的时候,它通过内置的LB组件向服务注册表查询目标服务地址列表,然后以某种负载策略选择目标服务地址
  • 这一个方案对服务注册表的可用性要求很高,一般采用能满足高可用分布式一致组件(zookeeper,consul,etcd)来实现
  • 进程内LB是一种分布式模式,LB和服务发现能力被分割到每一个服务消费者内部,同时服务消费方和服务提供方之间是一直调用,没有额外开销,性能较好。该方案以客户库(Client Library)的方式集成到服务调用方进程里头,如果企业内有多种不同的语言栈,就要配合开发多种不同的客户端,有一定的研发和维护成本。
  • 一旦客户端跟随服务调用方发布到生产环境中,后续如果要对客户库进行升级,势必要求服务调用方修改代码并重新发布,所以该方案的升级推广有不小的阻力。
    在这里插入图片描述

四、独立LB进程服务发现


  • 针对进程内LB模式不足的情况的一种折中方案
  • 与上个方案的不同之处,将LB和服务发现功能从进程内拆出来,变成主机上的一个独立进程,主机上的一个或是多个服务要访问目标服务的时候,他们都通过同一个主机上的独立的LB进程做服务发现或是负载均衡
  • LB独立进程可以进一步同消费服务能力解耦,以独立集群的方式来提供负载均衡的能力
  • 可以称为真正的软负载
  • 该方案也是一种分布式方案,没有单点问题,一个LB进程挂了只影响该主机上的服务调用方
  • 服务调用方和LB之间是进程内调用,性能好
  • 同时,该方案还简化了服务调用方,不需要为不同语言开发客户库,LB的升级不需要服务调用方改代码
    在这里插入图片描述

五、负载均衡


  • 系统的扩展分为垂直扩展和水平扩展
    🔥 横向:优雅终止,优雅启动
    🔥 纵向:从单机角度增加硬件处理能力
  • 负载均衡的作用(解决问题)
    🍺 并发压力
    🍺 故障转移
    🍺 通过增加或是减少服务,提高服务的伸缩性
    🍺 安全防护:白名单

(1)DNS负载均衡

最早的负载均衡技术,利用域名解析实现负载均衡,在DNS服务器,配置多个A记录,这些A记录对应的服务器构成集群。
在这里插入图片描述

在这里插入图片描述


(2)负载均衡技术(类比LVS)

在这里插入图片描述


【1】NAT(网络地址转换)

网络地址转换通常是通过修改数据包的源地址或目标地址来控制数据包的转发行为。
在这里插入图片描述


【2】新建TCP连接(NAT的优化)

为记录原始客户端ip地址,负载均衡功能不仅需要进行数据包的源目标地址修改,同时要记录原始客户端IP地址,基于简单的NAT无法满足此需求,于是衍生出了基于传输层协议的负载均衡的另一种方案—TCP/UDP Termination方案
在这里插入图片描述


【3】DR(直接路由,链路层负载均衡)

  • 在通信协议的数据链路层修改MAC地址进行负载均衡
  • 数据分发的时候,不修改IP地址,修改目标MAC地址,配置真实物理服务器集群所有机器虚拟IP和负载均衡服务器IP地址一致,达到不需改数据包的源地址和目标地址,进行数据分发的目的。
  • 实际处理服务器IP和数据请求目的IP一致。不需要经过负载均衡服务器进行地址转换,可将响应数据包直接返回给用户浏览器,可以有效避免负载均衡器网卡称为瓶颈,也称为直接路由(DR模式)

在这里插入图片描述


【4】TUN(隧道技术)

  • 负载均衡中常用的是隧道技术是IP over IP,其原理是保持原始数据包IP头不变,在IP头外层增加额外的IP包头后转发给上游服务器。额外IP包头肯定是 源负载均衡器ip -> 上游服务器实际网卡IP
  • 上游服务器接受IP数据包,解开外层IP包头后,剩下的是原始数据包
  • 同样的,原始数据包中的目标IP地址(负载均衡器的IP)要配置在上游服务器中某个虚拟网卡上,上游服务器处理完数据请求后,响应包通过这个虚拟网卡到达网关,网关直接返回给客户端。

推荐阅读
  • 小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限
    小王详解:内部网络中最易理解的NAT原理剖析,挑战你的认知极限 ... [详细]
  • 第二章:Kafka基础入门与核心概念解析
    本章节主要介绍了Kafka的基本概念及其核心特性。Kafka是一种分布式消息发布和订阅系统,以其卓越的性能和高吞吐量而著称。最初,Kafka被设计用于LinkedIn的活动流和运营数据处理,旨在高效地管理和传输大规模的数据流。这些数据主要包括用户活动记录、系统日志和其他实时信息。通过深入解析Kafka的设计原理和应用场景,读者将能够更好地理解其在现代大数据架构中的重要地位。 ... [详细]
  • 2019年后蚂蚁集团与拼多多面试经验详述与深度剖析
    2019年后蚂蚁集团与拼多多面试经验详述与深度剖析 ... [详细]
  • 利用 Python Socket 实现 ICMP 协议下的网络通信
    在计算机网络课程的2.1实验中,学生需要通过Python Socket编程实现一种基于ICMP协议的网络通信功能。与操作系统自带的Ping命令类似,该实验要求学生开发一个简化的、非标准的ICMP通信程序,以加深对ICMP协议及其在网络通信中的应用的理解。通过这一实验,学生将掌握如何使用Python Socket库来构建和解析ICMP数据包,并实现基本的网络探测功能。 ... [详细]
  • 阿里巴巴终面技术挑战:如何利用 UDP 实现 TCP 功能?
    在阿里巴巴的技术面试中,技术总监曾提出一道关于如何利用 UDP 实现 TCP 功能的问题。当时回答得不够理想,因此事后进行了详细总结。通过与总监的进一步交流,了解到这是一道常见的阿里面试题。面试官的主要目的是考察应聘者对 UDP 和 TCP 在原理上的差异的理解,以及如何通过 UDP 实现类似 TCP 的可靠传输机制。 ... [详细]
  • 在JavaWeb项目架构中,NFS(网络文件系统)的实现与优化是关键环节。NFS允许不同主机系统通过局域网共享文件和目录,提高资源利用率和数据访问效率。本文详细探讨了NFS在JavaWeb项目中的应用,包括配置、性能优化及常见问题的解决方案,旨在为开发者提供实用的技术参考。 ... [详细]
  • HBase Java API 进阶:过滤器详解与应用实例
    本文详细探讨了HBase 1.2.6版本中Java API的高级应用,重点介绍了过滤器的使用方法和实际案例。首先,文章对几种常见的HBase过滤器进行了概述,包括列前缀过滤器(ColumnPrefixFilter)和时间戳过滤器(TimestampsFilter)。此外,还详细讲解了分页过滤器(PageFilter)的实现原理及其在大数据查询中的应用场景。通过具体的代码示例,读者可以更好地理解和掌握这些过滤器的使用技巧,从而提高数据处理的效率和灵活性。 ... [详细]
  • C#中实现高效UDP数据传输技术
    C#中实现高效UDP数据传输技术 ... [详细]
  • Nacos 0.3 数据持久化详解与实践
    本文详细介绍了如何将 Nacos 0.3 的数据持久化到 MySQL 数据库,并提供了具体的步骤和注意事项。 ... [详细]
  • WCF类型共享的最佳实践
    在使用WCF服务时,经常会遇到同一个实体类型在不同服务中被生成为不同版本的问题。本文将介绍几种有效的类型共享方法,以解决这一常见问题。 ... [详细]
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • Iwouldliketohaveatooltopdisplayedonatextboxunderacertainsituation.我希望在特定情况下在文本框中显示工具栏 ... [详细]
  • 本章介绍了TCP/IP协议族中的链路层,其主要功能是为IP模块发送和接收IP数据报。链路层还支持一些辅助性协议,如ARP。此外,本文详细探讨了不同类型的链路层技术及其应用。 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 在ElasticStack日志监控系统中,Logstash编码插件自5.0版本起进行了重大改进。插件被独立拆分为gem包,每个插件可以单独进行更新和维护,无需依赖Logstash的整体升级。这不仅提高了系统的灵活性和可维护性,还简化了插件的管理和部署过程。本文将详细介绍这些编码插件的功能、配置方法,并通过实际生产环境中的应用案例,展示其在日志处理和监控中的高效性和可靠性。 ... [详细]
author-avatar
手机用户40405729304
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有