• nginx load balance


    load balance

    https://zhuanlan.zhihu.com/p/64777456

    四层负载均衡(tcp)

    在三层负载均衡的基础上,用 ip+port 接收请求,再转发到对应的机器。

    七层负载均衡(http)

    根据虚拟的 url 或 IP,主机名接收请求,再转向相应的处理服务器。

    在实际应用中,比较常见的就是四层负载及七层负载。这里也重点说下这两种负载。

    四层

    四层负载均衡(基于IP+端口的负载均衡)

    所谓四层负载均衡,也就是主要通过报文中的目标地址和端口,再加上负载均衡设备设置的服务器选择方式,决定最终选择的内部服务器。

    layer4

    1. 在三层负载均衡的基础上,通过发布三层的 IP 地址(VIP),然后加四层的端口号,来决定哪些流量需要做负载均衡,对需要处理的流量进行 NAT 处理,转发至后台服务器,并记录下这个 TCP 或者 UDP 的流量是由哪台服务器处理的,后续这个连接的所有流量都同样转发到同一台服务器处理。(注:NAT:Network Address Translation)
    2. 以常见的 TCP 为例,负载均衡设备在接收到第一个来自客户端的 SYN 请求时,即通过上述方式选择一个最佳的服务器,并对报文中目标 IP 地址进行修改(改为后端服务器 IP),直接转发给该服务器。TCP 的连接建立,即三次握手是客户端和服务器直接建立的,负载均衡设备只是起到一个类似路由器的转发动作。在某些部署情况下,为保证服务器回包可以正确返回给负载均衡设备,在转发报文的同时可能还会对报文原来的源地址进行修改。
    3. 对应的负载均衡器称为四层交换机(L4 switch),主要分析 IP 层及 TCP/UDP 层,实现四层负载均衡。此种负载均衡器不理解应用协议(如 HTTP/FTP/MySQL 等等)。要处理的流量进行 NAT 处理,转发至后台服务器,并记录下这个 TCP 或者 UDP 的流量是由哪台服务器处理的,后续这个连接的所有流量都同样转发到同一台服务器处理。
    4. 实现四层负载均衡的软件有:
    • F5:硬件负载均衡器,功能很好,但是成本很高
    • lvs:重量级的四层负载软件
    • nginx:轻量级的四层负载软件,带缓存功能,正则表达式较灵活
    • haproxy:模拟四层转发,较灵活

    七层

    七层的负载均衡(基于虚拟的 URL 或主机 IP 的负载均衡)

    所谓七层负载均衡,也称为“内容交换”,也就是主要通过报文中的真正有意义的应用层内容,再加上负载均衡设备设置的服务器选择方式,决定最终选择的内部服务器。

    layer7

    1. 在四层负载均衡的基础上(没有四层是绝对不可能有七层的),再考虑应用层的特征,比如同一个 Web 服务器的负载均衡,除了根据 VIP 加 80 端口辨别是否需要处理的流量,还可根据七层的 URL、浏览器类别、语言来决定是否要进行负载均衡。举个例子,如果你的 Web 服务器分成两组,一组是中文语言的,一组是英文语言的,那么七层负载均衡就可以当用户来访问你的域名时,自动辨别用户语言,然后选择对应的语言服务器组进行负载均衡处理。
    2. 以常见的 TCP 为例,负载均衡设备如果要根据真正的应用层内容再选择服务器,只能先代理最终的服务器和客户端建立连接(三次握手)后,才可能接受到客户端发送的真正应用层内容的报文,然后再根据该报文中的特定字段,再加上负载均衡设备设置的服务器选择方式,决定最终选择的内部服务器。负载均衡设备在这种情况下,更类似于一个代理服务器。负载均衡和前端的客户端以及后端的服务器会分别建立 TCP 连接。所以从这个技术原理上来看,七层负载均衡明显的对负载均衡设备的要求更高,处理七层的能力也必然会低于四层模式的部署方式。
    3. 对应的负载均衡器称为七层交换机(L7 switch),除了支持四层负载均衡以外,还有分析应用层的信息,如 HTTP 协议 URI 或 Cookie 信息,实现七层负载均衡。此种负载均衡器能理解应用协议。
    4. 实现七层负载均衡的软件有:
    • haproxy:天生负载均衡技能,全面支持七层代理,会话保持,标记,路径转移
    • nginx:只在 http 协议和 mail 协议上功能比较好,性能与 haproxy 差不多
    • apache:功能较差
    • Mysql proxy:功能尚可

    区别

    举个例子形象的说明:四层负载均衡就像银行的自助排号机,每一个达到银行的客户根据排号机的顺序,选择对应的窗口接受服务;而七层负载均衡像银行大堂经理,先确认客户需要办理的业务,再安排排号。这样办理理财、存取款等业务的客户,会根据银行内部资源得到统一协调处理,加快客户业务办理流程。

    深入理解

    https://www.snapt.net/glossary/layer-4-vs-layer-7-load-balancing-explained

    这里讲解比较能帮助理解

    不管是四层还是七层, LB始终处于中间, 中间的位置,要求其需要跟两边都能通信,

    则对于四层的TCP报文,经过LB时候,

       LB会将 源地址换成LB的地址, 目的地址换成 内部server的地址

      内部server响应TCP报文到LB, LB将目的地址换成客户端的地址,将源地址换换成LB地址

    总结:其仅仅做TCP报文的地址变化, 不做终结TCP连接, 这类似PROXY作用,市委门卫传达室专送信件。

    对于7层应用层报文请求,经过LB时候,

      LB终结了客户端到LB的TCP连接, 同时对应用层报文内容解读

      然后LB发起新的TCP连接到 内部服务器, 将应用层内容发给内部服务器

      内部服务器有响应时候, 报文沿着原路返回

    总结: 其会终结TCP连接, 这类似DELEGATE作用, 相当于市长秘书,会对信件内容阅读处理。

    Is a Layer 7 Load Balancer a Reverse Proxy?

    Raw throughput in Layer 7 (HTTP) mode is lower than TCP, and this is because the request coming into the Load Balancer isn’t simply proxied to the backend. The load balancer is actually acting in part as a middle man.

    The request for content/resources is made on behalf of the connection, by the load balancer to the backend servers. When the response is received, the content is served back to the inbound connection.

    Nginx配置

    https://www.cnblogs.com/nshgo/p/11727386.html

    四层

    stream {
          server {
              listen 30028;
              proxy_pass appserver;
          }
          upstream appserver{
              server 10.0.0.12:8080 weight=2;
              server 10.0.0.13:8080 weight=2;
          }
    }

    七层

    upstream appserver {
          server 10.0.0.12:8080 weight=2;
          server 10.0.0.13:8080 weight=2;
    }
    server {
        listen       80;
        server_name  localhost;
        location / {
           proxy_pass http://appserver;
        }  
  • 相关阅读:
    Oracle VM VirtualBox 虚拟机中桥接模式一直不能用 ,需要安装 VBoxNetLwf.inf
    Windows7窗口跑到屏幕外面
    手动操作群晖蜂鸣器指示灯方法
    DHT11温湿度传感器接入HomeBridge
    DIY树莓派Homebridge智能台灯
    群晖NAS局域网无法跑满千兆排查
    虚拟机性能监控与故障处理工具------JDK的命令行工具
    垃圾收集器与内存分配策略-内存分配与回收策略
    Minor GC 与Full GC有什么不一样
    java的关键字与保留字
  • 原文地址:https://www.cnblogs.com/lightsong/p/16842517.html
Copyright © 2020-2023  润新知