美文网首页小慢哥Linux运维
负载均衡获得真实源IP的6种方法

负载均衡获得真实源IP的6种方法

作者: 小慢哥Linux运维 | 来源:发表于2018-11-17 23:24 被阅读188次

原文链接

image

除了X-FORWARD-FOR,负载均衡中获得真实源IP的方法还有很多种。
本文抛砖引玉,主要介绍获得真实源IP的多种方法,而不是具体配置。
负载均衡获得真实IP的方法有很多种,将形成专题文章。
本文为第一篇,主要做介绍和优劣对比。

小慢哥的原创文章,欢迎转载


获得真实IP的6种方法

当数据包从负载均衡器往后端转发时候,真实源IP可在L3、L4、L7实现,并且分别有2种方法可以获得真实IP,因此共有6种方法:

保持L3层源IP不变,根据连接次数可以分为

  • 一次连接模式,如lvs
  • 二次连接模式,如haproxy的透明模式

在L4层数据里,添加源IP信息,有2种模式

  • 在4层的option字段里增加源IP信息,比如tcp option、udp option
  • 在4层末尾和7层开头之间,增加proxy protocol信息

在L7层数据里,增加源IP信息,有2种模式

  • 协议自带,例如HTTP的X-FORWARD-FOR
  • 业务程序自行实现

一次连接与二次连接

一次连接:负载均衡器对数据包仅做转发,而不对后端重新发起三次握手

二次连接:和一次连接相对应,在tcp转发时候,对后端重新进行了三次握手。上面所讲的L4和L7方法的负载均衡,都是二次连接

可以通过对比源端口是否有改变来简单判断是一次连接还是二次连接,端口没改变,可以理解为一次连接,有改变就是二次连接

方法1: L3的一次连接模式

介绍:是指在网络层不对源IP做修改,直接将数据包转发给后端,当后端接收到数据的时候,源IP就是真实IP。

实现:LVS-DR、LVS-NAT、LVS-TUNNEL模式。其中LVS-TUNNEL比较特别,是在原有数据包的开头封装了IP头,当后端收到数据的时候,将封装的IP头进行解封装,获得的就是原有数据包。

优点:逻辑简单,当负载均衡器故障切换的时候,从客户端到后端的tcp连接不会中断

缺点:对网络架构有要求,比如DR模式,要求后端配VIP,并且回包要能直接回到客户机;NAT模式,要求回包经过负载均衡器;TUNNEL模式要求后端支持IPIP隧道

方法2: L3的二次连接模式

介绍:是指负载均衡器和后端重新进行三次握手,但保持数据包的源IP为真实IP。

实现:haproxy(开启tproxy透明代理模式)+ iptables(fwmark打标记)+ 策略路由这3者组合才能实现

优点:可以实现L7层(如HTTP/HTTPS)的负载均衡,而一次连接主要实现L4层的负载均衡

缺点:配置最复杂,同时要求回包经过负载均衡器

方法3: L4的toa模式

介绍:在4层的option字段里增加源IP信息,比如在tcp option里增加源IP信息(称为toa)、udp option里增加源IP信息(称为uoa)

实现:负载均衡器配置lvs-fullnat(只支持toa),iqiyi/dpvs(支持toa和uoa);后端要加载toa、uoa模块,这个模块的作用是替换了后端应用程序获取IP的系统接口的钩子

优点:对网络架构要求低

缺点:lvs-fullnat需要编译内核,且只支持rhel/centos 6的内核,另外多年未更新;iqiyi/dpvs功能强大,但需要dpdk的支持;后端都需要加载toa/uoa模块,且只支持linux系统。

方法4: L4的proxy protocol模式

介绍:在L7层开头增加proxy protocol数据(该协议是haproxy发明),目前有v1(明文)和v2(二进制)版本

实现:负载均衡器和后端同时开启proxy protocol,haproxy和nginx均支持,不过haproxy的配置颗粒度更小,另外nginx转发数据时候只支持v1

优点:对网络架构要求低,只要程序支持即可,因此理论上没有操作系统限制

缺点:目前支持proxy protocol的程序较少,且两端只能都开启或者都不开启该协议,不能一端开一端不开

方法5: L7协议自带,例如HTTP的X-FORWARD-FOR

介绍:最常见的方法,协议自带源IP信息,或者可定制插入

实现:例如HTTP协议有X-FORWARD-FOR,也可以自己将源IP插入到HTTP头部信息里

优点:对网络架构要求低,配置简便

缺点:容易被伪造

方法6: L7层业务程序自行实现

介绍:最好的方法,就是业务方自行实现

实现:业务自行实现,例如在client端插入源IP信息,带到server端

优点:对网络架构无要求,只要网络可通即可,只要安全做好,不容易被伪造

缺点:业务方要有一定开发能力

总结

如果能做到无状态,不需要真实源IP,是最好的。因为这样对底层架构没有要求,底层架构就可以做的更高级更弹性。

如果一定要获得真实源IP,推荐方案的顺序就是倒推,从L7到L3,即首选方法6,如果不行再选用方法5,以此类推到方法1


微信公众号(小慢哥Linux运维)

每周一文,轻松学Linux运维

微信公众号

个人网站fzxiaomange.com

个人邮箱cyent@163.com

相关文章

  • 负载均衡获得真实源IP的6种方法

    原文链接 除了X-FORWARD-FOR,负载均衡中获得真实源IP的方法还有很多种。本文抛砖引玉,主要介绍获得真实...

  • 负载均衡

    负载均衡图例负载均衡.png 负载均衡策略 轮询 ip_hash 均衡参数 down 表示当前的服务不参与负载均衡...

  • Java中的代理

    隐藏服务器真实IP:使用反向代理,可以对客户端隐藏服务器的IP地址。 负载均衡:反向代理服务器可以做负载均衡,根据...

  • 简述四层和七层负载均衡的特点及Haproxy、nginx与LVS

    1、四层负载均衡与七层负载均衡 四层负载均衡指的是负载均衡设备通过报文中的目标IP地址和端口负载均衡算法,选择到达...

  • Nginx + PHP + Tomcat 配置负载均衡, 动静分

    Nginx + PHP + Tomcat 配置负载均衡,和动静分离。 负载均衡设计 |名称|IP|描述||--:-...

  • Heartbeat VIP/IP 与 别名/辅助IP

    真实IP 真实IP又被称为管理IP,一般是配置在物理网卡上的实际IP,这可以看作你本人的姓名,如:张三在负载均衡及...

  • Nginx负载均衡和双主热备

    CORS配置 防盗链配置 集群负载均衡 四层负载均衡是基于IP+端口的负载均衡,负载转发,记录连接由哪个服务器处理...

  • Nginx实现负载均衡

    Nginx负载均衡设置 一、负载均衡算法 实现负载均衡可有以下算法: 源地址哈希法:根据获取客户端的IP地址,通过...

  • nginx 负载均衡之ip_hash

    1. nginx 负载均衡之ip_hash ip_hash这种负载均衡模式根据个人理解就是:例如多个用户通过ngi...

  • 3.Nginx的反向代理

    nginx反向代理 反向代理就是负载均衡负载均衡分为四层负载和七层负载四层负载:基于IP+端口的负载七层负载:基于...

网友评论

    本文标题:负载均衡获得真实源IP的6种方法

    本文链接:https://www.haomeiwen.com/subject/oihwfqtx.html