<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
    <channel>
        <title>负载均衡 on IT 运维小秋</title>
        <link>/docs/%E6%9E%B6%E6%9E%84/gateway/lb/index.html</link>
        <description>Recent content in 负载均衡 on IT 运维小秋</description>
        <generator>Hugo -- gohugo.io</generator>
        <language>zh-cn</language>
        <managingEditor>chenwx716@139.com</managingEditor>
        <webMaster>chenwx716@139.com</webMaster>
        <lastBuildDate>Wed, 15 Jul 2020 12:53:32 +0800</lastBuildDate><atom:link href="/docs/%E6%9E%B6%E6%9E%84/gateway/lb/index.xml" rel="self" type="application/rss+xml" /><item>
        <title>产品选型</title>
        <link>/p/load-balancer-type-selection.html</link>
        <pubDate>Thu, 02 Mar 2023 10:30:00 +0800</pubDate>
        <author>chenwx716@139.com</author>
        <guid>/p/load-balancer-type-selection.html</guid>
        <description>&lt;h2 id=&#34;负载均衡的一般实现方式&#34;&gt;负载均衡的一般实现方式&lt;/h2&gt;
&lt;h3 id=&#34;1-七层实现&#34;&gt;1. 七层实现&lt;/h3&gt;
&lt;p&gt;如 nginx, HAProxy，traefik，硬件负载均衡器;&lt;/p&gt;
&lt;p&gt;一般承载协议：HTTP, HTTPS, WS等&lt;/p&gt;
&lt;p&gt;优点: 功能丰富, 灵活方便, 插件支持；如果不是性能和协议不满足，几乎不用考虑别的方式。&lt;/p&gt;
&lt;h3 id=&#34;2-四层实现&#34;&gt;2. 四层实现&lt;/h3&gt;
&lt;p&gt;承载协议：TCP, UDP&lt;/p&gt;
&lt;p&gt;实现：如 lvs, 硬件负载均衡器&lt;/p&gt;
&lt;p&gt;优点: 性能好，稳定性高&lt;/p&gt;
&lt;h3 id=&#34;3-三层实现&#34;&gt;3. 三层实现&lt;/h3&gt;
&lt;p&gt;一般靠交换机或路由器等网络设备去实现；&lt;/p&gt;
&lt;p&gt;采用等价路由, 流量镜像, 源 IP HASH 等方式, 在网络层按 IP 地址进行分发；&lt;/p&gt;
&lt;p&gt;特别大流量时可以考虑 OSPF+LVS 技术栈。&lt;/p&gt;
&lt;h3 id=&#34;4-二层负载&#34;&gt;4. 二层负载&lt;/h3&gt;
&lt;p&gt;原理: 后端多个服务器配置相同的 IP 地址，LB 通过改写数据帧的 MAC 地址来和后端通信&lt;/p&gt;
&lt;p&gt;例如：交换机的端口聚合&lt;/p&gt;
&lt;h3 id=&#34;5-dns-负载均衡&#34;&gt;5. DNS 负载均衡&lt;/h3&gt;
&lt;p&gt;通过 DNS 服务器给客户端响应不同的 IP 地址 或 多个IP地址的方式, 以达到负载均衡的效果；&lt;br /&gt;
在单个入口性能达到瓶颈时, 非常有效;&lt;/p&gt;
&lt;p&gt;如果使用智能 DNS, 还可以做到如:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;不同区域的用户请求不同地址, 做到区域划分, 就近访问, 提高不同区域的响应性能;&lt;/li&gt;
&lt;li&gt;也可以将静态资源解析到 CDN, 动态资源解析到主入口;&lt;/li&gt;
&lt;li&gt;配合健康检查做故障转移, 早期的DNS服务一般不支持探活，但目前很多也开始支持了，例如某些厂家推的全局DNS。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;缺点: 使用 DNS 就绕不过去客户端缓存问题, 于是配置更新生效的时间就不稳定;&lt;/p&gt;
&lt;h3 id=&#34;6-客户端负载均衡&#34;&gt;6. 客户端负载均衡&lt;/h3&gt;
&lt;p&gt;方法一: 客户端有一个IP或域名列表，随机或其它方式选择一个目标地址进行请求；&lt;/p&gt;
&lt;p&gt;方法二: 客户端先请求或监听某个接口, 获取一个 ip 列表, 然后再发起请求。&lt;/p&gt;
&lt;h3 id=&#34;7-基础网络协议&#34;&gt;7. 基础网络协议&lt;/h3&gt;
&lt;p&gt;ipv6 的任播(Anycast):&lt;br /&gt;
通过路由寻址协议，可以把 包 发给最近或响应最好的一台设备上；&lt;/p&gt;
&lt;p&gt;IPv4 的组播：&lt;br /&gt;
例如多个后端节点监听同一个组播地址, 但根据源IP hash 来决定自己是否处理这个包，也达到了类似效果。&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;选型时功能要求&#34;&gt;选型时功能要求&lt;/h2&gt;
&lt;h3 id=&#34;1-核心要求&#34;&gt;1. 核心要求&lt;/h3&gt;
&lt;ul&gt;
&lt;li&gt;性能需求&lt;/li&gt;
&lt;li&gt;稳定性要求: 有没有经过大厂考验&lt;/li&gt;
&lt;li&gt;协议支持; 如 TCP，UDP，HTTP，HTTPS，WebSocket 等&lt;/li&gt;
&lt;li&gt;负载均衡算法支持&lt;/li&gt;
&lt;li&gt;健康检查策略: 主动检查和被动检查&lt;/li&gt;
&lt;li&gt;有没有扩展为 API 网关或业务网关的规划&lt;/li&gt;
&lt;li&gt;动态服务发现功能&lt;/li&gt;
&lt;li&gt;热更新: 如配置热更新，以及程序自身的热更新&lt;/li&gt;
&lt;/ul&gt;
&lt;h3 id=&#34;2-辅助功能要求&#34;&gt;2. 辅助功能要求&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;https协议支持程度, ssl 卸载，ssl 算法调整&lt;/li&gt;
&lt;li&gt;安全性要求: 黑白名单, 动态黑白名单&lt;/li&gt;
&lt;li&gt;扩展性，插件支持&lt;/li&gt;
&lt;li&gt;多节点管理方便程度&lt;/li&gt;
&lt;/ol&gt;
&lt;h3 id=&#34;3-管理类功能&#34;&gt;3. 管理类功能&lt;/h3&gt;
&lt;ol&gt;
&lt;li&gt;http 重定向 https: 避免进入到应用内再进行重定向&lt;/li&gt;
&lt;li&gt;添加 XFF 头&lt;/li&gt;
&lt;li&gt;修改请求 url&lt;/li&gt;
&lt;li&gt;丰富的日志输出&lt;/li&gt;
&lt;li&gt;监控需求, 有些是带监控面板, 有些是暴露了一些指标供外部采集；&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;按业务场景选择&#34;&gt;按业务场景选择&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;业务量较低&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;更需要关注功能丰富而非性能，日 PV 小于 1000 万时, 推荐 nginx, traefix 等 7 层组件;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;业务量中等时&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;需要开始考虑性能, 可以考虑 lvs+nginx;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;业务量很高时&lt;/strong&gt;&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;分拆入口: 如 DNS 多 IP 地址轮询, 或者 二级域名 image.wait.com voide.wait.com, 或用户分区;&lt;/li&gt;
&lt;li&gt;不能拆入口时: 网络层处理流量负载(如ospf), 硬件负载设备处理业务负载;&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;&lt;strong&gt;业务量特别大&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;基于网络层的地址多路由; 即同一个 IP 地址不同区域解析到不同服务器上，例如泛播&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;常用产品分析&#34;&gt;常用产品分析&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;nginx&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;一般业务场景足够, 高性能;&lt;/li&gt;
&lt;li&gt;功能丰富, 成熟, 通用度高&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;haproxy&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;早期的产品, 支持四层和七层, 功能丰富&lt;/li&gt;
&lt;li&gt;除非特定生态, 现在一般不用&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;traefik&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;特点在于动态发现后端服务变更&lt;/li&gt;
&lt;li&gt;适合容器化场景&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;lvs&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;更适合做 4 层的负载&lt;/li&gt;
&lt;li&gt;属于内核级, 性能好, 稳定高, 资源使用率低, 没有多余的流量产生,&lt;/li&gt;
&lt;li&gt;有一个 fullnat 模块, 增加了 local address&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;ospf+lvs&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;先在交换机上进行一次流量负载&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;strong&gt;端口聚合&lt;/strong&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;单台主机和交换机之间, 通过端口聚合, 可以扩大带宽并且线路冗余&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;优化项&#34;&gt;优化项&lt;/h2&gt;
&lt;ol&gt;
&lt;li&gt;
&lt;p&gt;服务器直接返回请求&lt;br /&gt;
用户的请求进来时需要穿越多层负载, 为避免响应的包也回溯多层,&lt;br /&gt;
可以将响应包由后端直接回给用户，不从 LB 再过一次, 提高性能。&lt;br /&gt;
适合大文件下载的场景;&lt;/p&gt;
&lt;p&gt;例如 cilium 的 DSR模式, lvs 的 DR 模型, 某些硬件负载均衡器的 三角模型&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;增加上游服务数量&lt;br /&gt;
一般来说增加服务数量而不是让每个服务处理更多的通信, 可以得到更低的延迟, 和更高吞吐量&lt;/p&gt;
&lt;/li&gt;
&lt;li&gt;
&lt;p&gt;关于 ssl 卸载&lt;br /&gt;
加密解密是很耗CPU的，如果有https大文件下载场景, 最好不要把 ssl 卸载放在 lb 上，影响性能。&lt;/p&gt;
&lt;/li&gt;
&lt;/ol&gt;
</description>
        </item>
        <item>
        <title>负载均衡算法</title>
        <link>/p/load-balancer-algorithm.html</link>
        <pubDate>Thu, 02 Mar 2023 10:30:00 +0800</pubDate>
        <author>chenwx716@139.com</author>
        <guid>/p/load-balancer-algorithm.html</guid>
        <description>&lt;h2 id=&#34;负载均衡算法&#34;&gt;负载均衡算法&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;说明事项&lt;/strong&gt;&lt;/p&gt;
&lt;p&gt;不同模型下对于代理后面的的服务器叫法不一样, 有时候叫 &lt;strong&gt;上游&lt;/strong&gt;(nginx), 有时候叫 &lt;strong&gt;后端&lt;/strong&gt;，有的又叫 &lt;strong&gt;RS&lt;/strong&gt;(lvs 的 RealServer)，还有直接叫 &lt;strong&gt;server&lt;/strong&gt; 的，大家知道是同一个东西就行。&lt;/p&gt;
&lt;p&gt;简单分类&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;静态算法, 固定分发策略&lt;/li&gt;
&lt;li&gt;动态算法(根据状态的不同分配方式由所变化)&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;静态算法&#34;&gt;静态算法&lt;/h2&gt;
&lt;h3 id=&#34;1-rr-round-robin-轮询&#34;&gt;1. RR (Round-Robin) 轮询&lt;/h3&gt;
&lt;p&gt;轮流请求后端服务&lt;/p&gt;
&lt;p&gt;优点：简单，性能高&lt;br /&gt;
特点: 不记录当前连接的状态，是一种无状态调度&lt;br /&gt;
缺点: 如果后端资源配置不一样, 容易造成负载不平衡&lt;/p&gt;
&lt;h3 id=&#34;2-wrr-weighted-round-robin-加权轮询&#34;&gt;2. WRR (Weighted Round-Robin) 加权轮询&lt;/h3&gt;
&lt;p&gt;在 RR 的基础上，可以增加或减少分配给某个后端应用的流量比例;&lt;/p&gt;
&lt;p&gt;场景: 应对后台服务性能不一致的场景, 性能好的服务器多处理一点流量;&lt;/p&gt;
&lt;p&gt;例如: A=1, B=2;&lt;/p&gt;
&lt;p&gt;则请求 1 给 A, 请求 2,3 给 B, 请求 4 给 A, 请求 5,6 给 B&lt;/p&gt;
&lt;h3 id=&#34;3-random-随机算法&#34;&gt;3. random 随机算法&lt;/h3&gt;
&lt;p&gt;轮询算法实际上还是按列表环进行顺序分配;&lt;/p&gt;
&lt;p&gt;而全随机算法, 在数据量足够大的场景下, 能达到均衡分布;&lt;/p&gt;
&lt;h3 id=&#34;4-ip-hash-source-hashing&#34;&gt;4. ip hash (Source Hashing)&lt;/h3&gt;
&lt;p&gt;区分2种场景&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;使用 源ip地址进行 hash, 一般是处理进来的流量, 源地址散列, 或源地址 HASH, 简称 SH&lt;/li&gt;
&lt;li&gt;使用 目的ip地址进行 hash, 一般是处理出去的流量, Destination Hashing 简称 DH&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;根据这个请求的源地址进行 hash, 然后从地址列表中找出一个服务器来; 类似与 取模 运算；&lt;/p&gt;
&lt;p&gt;优点: 同一个客户端IP的请求始终会落到一个后端节点，便于 cookie 与 session 进行会话绑定；&lt;br /&gt;
缺点: 后端新增或减少一个节点时，将有 1/n 流量始终不可用, 如果重启或重载配置, 则原来映射关系就会全部重新排。&lt;/p&gt;
&lt;h3 id=&#34;5-一致性哈希&#34;&gt;5. 一致性哈希&lt;/h3&gt;
&lt;p&gt;简单理解: 划一个圈, 每个节点占一个范围；&lt;/p&gt;
&lt;p&gt;如果有新增服务器, 就圈内找最合适的一个节点, 将它的一部分范围转交给新节点;&lt;br /&gt;
也可以是两个相邻节点各出让一部分&lt;br /&gt;
如果是某各节点故障, 就把它原来的这个范围, 给它相邻的两个节点进行瓜分；&lt;/p&gt;
&lt;p&gt;优点: 可以在客户端实现&lt;br /&gt;
缺点: 节点变化时需要操作的内容有些多, 适合在客户端实现, 而不是 LB&lt;/p&gt;
&lt;h3 id=&#34;6-序列分配&#34;&gt;6. 序列分配&lt;/h3&gt;
&lt;p&gt;根据键的序列进行分配; 如 ID 为 1-1000 分到 A 节点, 1001-2000 分配到 B 节点&lt;/p&gt;
&lt;h3 id=&#34;7-取模分配&#34;&gt;7. 取模分配&lt;/h3&gt;
&lt;p&gt;对 key 和节点数进行取模计算后分配到相应节点&lt;/p&gt;
&lt;h2 id=&#34;动态算法&#34;&gt;动态算法&lt;/h2&gt;
&lt;h3 id=&#34;1-最小连接数least-connection--简称-lc&#34;&gt;1. 最小连接数(Least-Connection ) 简称 LC&lt;/h3&gt;
&lt;p&gt;对当前与后端服务器的连接进行统计, 谁少就把新连接给谁;&lt;/p&gt;
&lt;p&gt;适合场景: 下载类的服务，小文件下载连接释放得快&lt;/p&gt;
&lt;h3 id=&#34;2-加权最少链接weighted--least-connection-简称-wlc&#34;&gt;2. 加权最少链接(Weighted  Least-Connection) 简称 WLC&lt;/h3&gt;
&lt;p&gt;在 LC 的基础上增加了权重, 权重高的可以承受更多连接&lt;/p&gt;
&lt;h3 id=&#34;3-最快响应模式&#34;&gt;3. 最快响应模式&lt;/h3&gt;
&lt;p&gt;传递连接给那些响应最快的服务器&lt;/p&gt;
&lt;h3 id=&#34;4-其它算法&#34;&gt;4. 其它算法&lt;/h3&gt;
&lt;p&gt;还有一些 lvs 的不常用算法, 比较复杂，特定场景下可能有用&lt;/p&gt;
&lt;p&gt;LBLC(局部性的最少链接): 先去目标ip的最近调度服务器, 如果不可用, 再使用 lc 算法;&lt;/p&gt;
&lt;p&gt;LBLCR(带复制的基于局部性最少链接): 比较复杂。先去一个目标服务器小组, 按lc算法选一个节点; 如果节点不可用再选;&lt;br /&gt;
SED(最短期望延迟),&lt;br /&gt;
NQ(Never Queue)&lt;br /&gt;
最快响应模式&lt;/p&gt;
&lt;h3 id=&#34;5-自定义控制&#34;&gt;5. 自定义控制&lt;/h3&gt;
&lt;p&gt;如根据监控系统内的 CPU 使用率和连接数,当前大事务量等, 来改变注册中心内配置的权重&lt;br /&gt;
劣势: 实现复杂&lt;br /&gt;
优点: 非常灵活&lt;/p&gt;
</description>
        </item>
        <item>
        <title>获取真实源IP地址</title>
        <link>/p/load-balancer-client-ip.html</link>
        <pubDate>Sat, 25 Feb 2023 12:30:00 +0800</pubDate>
        <author>chenwx716@139.com</author>
        <guid>/p/load-balancer-client-ip.html</guid>
        <description>&lt;p&gt;一般来说普通 http 场景，推荐使用 xff 头的方式获取IP，&lt;/p&gt;
&lt;p&gt;如果是 tcp 或 udp，先看是否支持 proxy protocol 协议，然后再考虑 lvs。&lt;/p&gt;
&lt;h2 id=&#34;简述&#34;&gt;简述&lt;/h2&gt;
&lt;ol&gt;
&lt;li&gt;从 xxf 头部获取&lt;/li&gt;
&lt;li&gt;四层从 proxy protocol 协议或者 tcp option 字段&lt;/li&gt;
&lt;li&gt;三层使用透明模型&lt;/li&gt;
&lt;li&gt;自定义规则, 需要客户端支持&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id=&#34;一从应用层获取&#34;&gt;一、从应用层获取&lt;/h2&gt;
&lt;h3 id=&#34;1-http协议规范的xff头部&#34;&gt;1. http协议规范的xff头部&lt;/h3&gt;
&lt;p&gt;如 http 协议约定, X-FORWARD-FOR 头部用于存放源IP地址&lt;/p&gt;
&lt;p&gt;如 nginx 一般配置&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-text&#34; data-lang=&#34;text&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;proxy_set_header X-Real-IP $remote_addr;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;优点: 对网络架构要求低, 配置简便&lt;/p&gt;
&lt;p&gt;缺点: 容易被伪造&lt;/p&gt;
&lt;h3 id=&#34;2-业务程序自行实现&#34;&gt;2. 业务程序自行实现&lt;/h3&gt;
&lt;p&gt;即程序自行实现, 例如 client 端将源IP插入到报文正文内某字段, 再带到 server 端。&lt;/p&gt;
&lt;p&gt;优点: 对网络架构无要求, 只要网络可通即可, 只要安全做好, 不容易被伪造&lt;/p&gt;
&lt;p&gt;缺点: 需要改造旧的客户端和服务器&lt;/p&gt;
&lt;h2 id=&#34;二从四层获取tcpip-也就是端口这一层&#34;&gt;二、从四层获取(TCP/IP 也就是端口这一层)&lt;/h2&gt;
&lt;h3 id=&#34;1-tcp-option-字段&#34;&gt;1. tcp option 字段&lt;/h3&gt;
&lt;p&gt;原理: 在 4 层报文的 option 字段里增加源 IP 信息, 比如 tcp option, udp option，即 L4 的 toa 模式；&lt;/p&gt;
&lt;p&gt;注:&lt;br /&gt;
toa 是指在 tcp option 里增加源 IP 信息；&lt;br /&gt;
uoa 是指在 udp option 里增加源 IP 信息；&lt;/p&gt;
&lt;p&gt;实现: lvs-fullnat(只支持 toa), iqiyi/dpvs(支持 toa 和 uoa);&lt;/p&gt;
&lt;p&gt;后端应用程序也要加载 toa, uoa 模块, 是用于替换后端应用程序获取 IP 时的系统接口的钩子。&lt;/p&gt;
&lt;p&gt;优点: 对网络架构要求低。&lt;/p&gt;
&lt;p&gt;缺点: lvs-fullnat 需要编译内核, 且多年未更新;&lt;br /&gt;
iqiyi/dpvs 功能强大, 但需要 dpdk 的支持;&lt;br /&gt;
而且都需要后端程序需要加载 toa/uoa 模块, 且只支持 linux 系统。&lt;/p&gt;
&lt;h3 id=&#34;2-proxy-protocol-协议支持&#34;&gt;2. proxy protocol 协议支持&lt;/h3&gt;
&lt;p&gt;原理:&lt;br /&gt;
即在三次握手结束后的第一个数据包的头部插入一段数据, 记录着源IP地址, 这段数据在 4 层末尾和 7 层开头之间。&lt;/p&gt;
&lt;p&gt;这项协议最早是 haproxy 开发推广的, 目前主流 proxy 应该是都支持了；&lt;/p&gt;
&lt;p&gt;目前有 v1(明文)和 v2(二进制)两个版本；&lt;/p&gt;
&lt;p&gt;优点: 网络侧不需要改造什么, 只要应用软件支持即可。&lt;/p&gt;
&lt;p&gt;限制条件:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;需要负载均衡器和后端同时开启 proxy protocol 协议，不能只开一侧；&lt;/li&gt;
&lt;li&gt;支持此协议的后端应用比较少;&lt;br /&gt;
已知支持此协议的软件: haproxy, nginx, apache、traefik、squid、mysql等,&lt;/li&gt;
&lt;li&gt;已经支持的 LB 还得看支持什么版本，如阿里云的CLB只支持V2版本，&lt;br /&gt;
nginx 早期只支持 v1 版本，1.13.11+ 才支持 v2 版本。&lt;/li&gt;
&lt;/ol&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt; 1
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 2
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 3
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 4
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 5
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 6
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 7
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 8
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt; 9
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;10
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;11
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;12
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;13
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;14
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;15
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;16
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;17
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-text&#34; data-lang=&#34;text&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;nginx 配置示例
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;插入配置
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;server {
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    listen              12345;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    proxy_pass          backend.example.com:8080;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    proxy_protocol      on;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;}
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;接收配置
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;server {
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    listen 80   proxy_protocol;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    listen 443  ssl proxy_protocol;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    real_ip_header  proxy_protocol;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;    proxy_set_header X-Forwarded-For $proxy_protocol_addr;
&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;}
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;h2 id=&#34;三从三层获取ip层&#34;&gt;三、从三层获取(IP层)&lt;/h2&gt;
&lt;h3 id=&#34;1-转发模式&#34;&gt;1. 转发模式&lt;/h3&gt;
&lt;p&gt;如果 LB 采用一次连接模式, 即只转发包，非代理模式时, 可以在网络层不对源 IP 做修改, 直接将数据包转发给后端, 当后端接收到数据的时候, 源 IP 就是真实 IP。&lt;/p&gt;
&lt;p&gt;实现: LVS-DR, LVS-NAT, LVS-TUNNEL 模式;&lt;/p&gt;
&lt;p&gt;优点: 逻辑简单, 当负载均衡器故障切换的时候, 从客户端到后端的 tcp 连接不会中断&lt;/p&gt;
&lt;p&gt;缺点: 对网络架构有要求, 例如&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;LVS-TUNNEL&lt;/strong&gt; 比较特别, 走的是隧道, 在原有数据包的开头封装了 IP 头, 当后端收到数据的时候, 将封装的 IP 头进行解封装, 获得的就是原始数据包，当然包括真实的 client IP。但是要后端也支持 ip 隧道。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;DR 模式&lt;/strong&gt;, 要求后端配 VIP, 并且回包要能直接回到客户机;&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;NAT 模式&lt;/strong&gt;, 要求回包经过负载均衡器;&lt;/p&gt;
&lt;h3 id=&#34;2-代理模式&#34;&gt;2. 代理模式&lt;/h3&gt;
&lt;p&gt;如果 LB 采用二次连接模式, 如 haproxy 的透明模式。&lt;/p&gt;
&lt;p&gt;是指负载均衡器和后端会重新进行三次握手, 但保持数据包的源 IP 为真实 IP，类似于 F5 的透明模式。&lt;/p&gt;
&lt;p&gt;实现原理: haproxy(开启 tproxy 透明代理模式)+ iptables(fwmark 打标记)+ 策略路由这 3 者组合才能实现。&lt;/p&gt;
&lt;p&gt;优点: 可以实现 L7 层(如 HTTP/HTTPS)的负载均衡, 而一次连接方式主要是实现 L4 层的负载均衡。&lt;/p&gt;
&lt;p&gt;缺点: 配置最复杂, 同时要求回包经过负载均衡器&lt;/p&gt;
&lt;hr /&gt;
&lt;h2 id=&#34;代理的一次连接和二次连接模式&#34;&gt;代理的一次连接和二次连接模式&lt;/h2&gt;
&lt;p&gt;一次连接: 负载均衡器对数据包仅做转发, 而不对后端重新发起三次握手,类似交换机&lt;/p&gt;
&lt;p&gt;二次连接: 和一次连接相对应, 在 tcp 转发时候, 对后端重新进行了三次握手,代理模式&lt;/p&gt;
&lt;p&gt;可以通过对比源端口是否有改变来简单判断是一次连接还是二次连接,&lt;/p&gt;
&lt;p&gt;端口没改变, 可以理解为一次连接, 有改变就是二次连接&lt;/p&gt;
</description>
        </item>
        
    </channel>
</rss>
