k8s ingress获取客户端客户端真实IP

背景

在Kubernetes中,获取客户端真实IP地址是一个常见需求。这是因为在负载均衡架构中,原始请求的源IP地址会被替换成负载均衡器的IP地址。

获取客户端真实IP的需求背景包括以下几点:

  1. 安全性:基于客户端IP进行访问控制和认证授权可以提高系统安全性。
  2. 日志记录与审计:记录真实IP有助于监测、故障排除和合规性审计。
  3. 统计与分析:了解用户来源地区和行为可以提供有价值的数据支持,用于业务决策和优化资源分配。
  4. 反欺诈与风险评估:根据真实IP进行欺诈检测、风险评估或地理位置相关功能能够提高准确性和可靠性。
    通过适当配置Kubernetes Ingress和相关组件,可以确保将原始请求中的真实IP正确传递给后端服务,满足上述需求并提供更精确、安全和可靠的服务。

配置方法

以阿里云ack集群中安装的ingress-nginx为例

方法1 命令行添加方法

1.获取ingress-nginx-controllerconfigmap配置文件名称

[root@K8SMASTER01 ~]# kubectl get -n kube-system deployment ack-ingress-nginx-controller -oyaml|grep configmap
        - --configmap=$(POD_NAMESPACE)/ack-ingress-nginx-controller

2.编辑ingress-nginx-controller的configmap配置文件

添加一下参数到配置文件中添加层级如下图

compute-full-forwarded-for = true
forwarded-for-header = X-Forwarded-For
use-forwarded-headers =true

kubectl edit -n kube-system cm ack-ingress-nginx-controller

在这里插入图片描述
保存退出即可,立即生效无需重启pod

方法2 控制台添加

1.查看ingress-nginx-controller的yaml文件
在这里插入图片描述
2.去到k8s集群控制台配置项选项
在这里插入图片描述
3.添加以下配置点击保存即可
在这里插入图片描述

`HttpServletRequest`通常是在传统的Web应用服务器环境中使用的,比如Spring Boot应用部署在Tomcat、Jetty等容器内。但在Kubernetes(K8S)的微服务架构中,由于网络代理和负载均衡的存在,直接从请求中获取客户端真实IP地址可能会变得复杂。 在K8S中,当流量经过 ingress controller 或集群内部的服务发现机制,请求的真实IP通常会被隐藏,为了获取客户端真实IP,你可以通过以下几种方式: 1. **头部注入**:如果Ingress支持,可以配置将客户端IP保留在`X-Real-Ip`, `X-Forwarded-For` 或 `X-Original-For`这样的HTTP头部。然后在代码里可以通过`HttpServletRequest.getHeader()`方法读取这些字段。 2. **环境变量**:一些Ingress控制器如Traefik提供了环境变量的方式,如`$traefik_http_request_header_x_real_ip`,应用可以直接读取这些环境变量。 3. **使用特定库**:例如在Spring Boot中,可以使用Spring Cloud LoadBalancer或Spring Security的自定义过滤器来处理这种情况。 4. **使用K8S注解**:对于Service,可以使用`metadata.annotations.kubernetes.io/service-node-port-range`注解指定NodePort范围,并在Service上设置`type: NodePort`,这样可以通过访问NodePort端口获取到原始请求的IP。 ```java String remoteIp = request.getHeader("x-real-ip") != null ? request.getHeader("x-real-ip") : request.getRemoteAddr(); ``` 请注意,实际操作会根据你的K8S配置和选择的解决方案有所不同。如果你需要更详细的指导,可能需要查阅对应Ingress控制的具体文档或咨询运维团队。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不爱吃肉@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值