热门标签 | 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)要配置在上游服务器中某个虚拟网卡上,上游服务器处理完数据请求后,响应包通过这个虚拟网卡到达网关,网关直接返回给客户端。

推荐阅读
  • TiDB | TiDB在5A级物流企业核心系统的应用与实践
    TiDB在5A级物流企业核心系统的应用与实践前言一、业务背景科捷物流概况神州金库简介二、现状与挑战神州金库现有技术体系业务挑战应对方案三、TiDB解决方案测试迁移收益问题四、说在最 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • 提供:ZStack云计算原创2016-12-26张鑫讲师介绍张鑫ZStack总架构师、联合创始人《系统虚拟化》主要作者,曾任职Intel开源软件技术中心 ... [详细]
  • 域名解析系统DNS
    文章目录前言一、域名系统概述二、因特网的域名结构三、域名服务器1.根域名服务器2.顶级域名服务器(TLD,top-leveldomain)3.权威(Authoritative)域名 ... [详细]
  • Kubernetes(k8s)基础简介
    Kubernetes(k8s)基础简介目录一、Kubernetes概述(一)、Kubernetes是什么(二& ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • [翻译]微服务设计模式5. 服务发现服务端服务发现
    服务之间需要互相调用,在单体架构中,服务之间的互相调用直接通过编程语言层面的方法调用就搞定了。在传统的分布式应用的部署中,服务地 ... [详细]
  • 服务网关与流量网关
    一、为什么需要服务网关1、什么是服务网关传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务,如果没有网关& ... [详细]
  • k8s+springboot+Eureka如何平滑上下线服务
    k8s+springboot+Eureka如何平滑上下线服务目录服务平滑上下线-k8s版本目录“上篇介绍了springboot+Euraka服务平滑上下线的方式,有部分小伙伴反馈k ... [详细]
  • ZooKeeper 学习
    前言相信大家对ZooKeeper应该不算陌生。但是你真的了解ZooKeeper是个什么东西吗?如果别人面试官让你给他讲讲ZooKeeper是个什么东西, ... [详细]
  • IP、ARP、TCP、UDP、ICMP、DNS、路由协议、DHCP协议的缺陷,容易受到的攻击,以及防御措施1、IP协议1.1、介绍: ... [详细]
  • Java工程师书单(初级,中级,高级)
    简介怎样学习才能从一名Java初级程序员成长为一名合格的架构师,或者说一名合格的架构师应该有怎样的技术知识体系,这是不仅一个刚刚踏入职场的初级程序员也是工作一两年之后开始迷茫的程序 ... [详细]
  • 什么是网关服务器初学linux服务器开发时,我们的服务器是很简单的,只需要一个程序完成与客户端的连接,接收客户端数据,数据处理,向客户端发送数据。但是在处理量很大的情况下,一 ... [详细]
  • 朱晔的互联网架构实践心得S1E7:三十种架构设计模式(上)【下载本文PDF进行阅读】设计模式是前人通过大量的实践总结出来的一些经验总结和最佳实践。在经过多年的软件开发实践之后,回过头 ... [详细]
  • Java开发实战讲解!字节跳动三场技术面+HR面
    二、回顾整理阿里面试题基本就这样了,还有一些零星的问题想不起来了,答案也整理出来了。自我介绍JVM如何加载一个类的过程,双亲委派模型中有 ... [详细]
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社区 版权所有