首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不从入口控制器获取源IP

不从入口控制器获取源IP
EN

Stack Overflow用户
提问于 2021-06-02 12:24:48
回答 1查看 1.4K关注 0票数 0

我们已经安装了EKS集群来部署应用程序。业务流为Nginx->LB->IngressController->Application.其中,nginx是L7代理。我们已经设置了下面的参数来转发报头中的源IP。

代码语言:javascript
复制
location ~* /example/version/test {
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For   $proxy_add_x_forwarded_for;
        proxy_pass http://second.example.com;
    }

请求被转发到AWS,我们已经安装了它和入口控制器。在入口控制器configmap中,我们添加了这些参数,从X转发的/Forwarded中提取源IP。

代码语言:javascript
复制
proxy-real-ip-cidr: <VPC CIDR>
use-forward-headers: "true"

当请求到达pod时,它将在Forwarded和X转发的报头中显示EKS节点IP地址。我又添加了一个自定义标题"ip- test“来测试转发的报头,如下所示。

代码语言:javascript
复制
location ~* /example/version/test {
        proxy_set_header X-Real-IP $remote_addr;
        add_header X-Forwarded-For   $proxy_add_x_forwarded_for;
        proxy_set_header 'ip-test' $remote_addr;
        proxy_pass http://second.example.com;
    }

令人惊讶的是,这个报头显示的是实际的源IP,但是X转发-For和forwarded只显示节点IP。我读过许多人建议添加externalTrafficPolicy: Local的文章,但在我们的例子中没有起作用。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-09 11:32:43

入口控制器nginx.conf也设置了proxy_set_header X-Real-IP $remote_addr;指令。我在ingress中添加了下面的注释,它起了作用。

代码语言:javascript
复制
nginx.ingress.kubernetes.io/configuration-snippet: |
      real_ip_header X-Real-IP;
      real_ip_recursive on;
      set_real_ip_from <VPC CIDR>;
      set_real_ip_from <PROXY IP>;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67805064

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档