解决kubernetes中ingress-nginx配置问题

本文探讨了如何在Kubernetes Ingress中使用Nginx控制器进行流量管理,包括解决大请求头问题和请求超时,通过添加自定义配置来优化性能。重点介绍了如何调整`client_header_buffer_size`和`proxy_read_timeout`。

HTTP(S)负载均衡器-ingress

Ingress是kubernetes API的标准资源类型之一,其本质就是一组基于DNS名称(host)或URL路径把请求转发至指定的Service资源的规则, 用于将集群外的请求流量转发至集群内部完成服务发布 

Ingress控制器(Ingress Controller)可以由任何具有反向代理(HTTP/HTTPS)功能的服务程序实现,如Nginx、Envoy、HAProxy、Vulcand和Traefik等。Ingress控制器本身也作为Pod对象与被代理的运行为Pod资源的应用运行于同一网络中。我们在这里选择了NGINX Ingress Controller,由于对NGINX的配置较为熟悉,同时我们使用的kubernetes是阿里云的容器服务,构建集群的时候,容器服务会自带NGINX Ingress Controller。

根据实际情况Ingress调优


解决400 Request Header Or Cookie Too Large问题

现象 :微信小程序需要调用后端接口,需要在header中传一段很长的token参数,直接使用浏览器访问该端口可以访问通,但是在加上token访问之后,会报“400 Request Header Or Cookie Too Large

<html>
      <head>
          <title>400 Request Header Or Cookie Too Large</title>
      </head>
      <body>
          <center>
              <h1>400 Bad Request</h1>
          </center>
          <center>Request Header Or Cookie Too Large</center>
          <hr>
          <center>nginx/1.15.6</center>
      </body>
  </html>

问题定位 :直接修改Service使用nodeport的形式访问,则没有报错,初步定位需要在ingress中nginx配置客户端的请求头,进入Ingress Controller的Pod查询配置,果然是请求头空间不足。

www-data@nginx-ingress-controller-5vx7x:/etc/nginx$ cat nginx.conf | grep client_header_buffer_size
        client_header_buffer_size       1k;
    www-data@nginx-ingress-controller-5vx7x:/etc/nginx$ cat nginx.conf | grep large_client_header_buffers
        large_client_header_buffers     4 8k;

解决方法 :在ingress中添加注释

nginx.ingress.kubernetes.io/server-snippet: client_header_buffer_size 2046k;

Server snippet
Using the annotation nginx.ingress.kubernetes.io/server-snippet it is possible to add custom configuration in the server configuration block.
该注释是将自定义配置加入nginx的server配置中

解决请求超时问题

现象 :有一个数据导出功能,需要将大量数据进行处理,然后以Excel格式返回,在导出一个大约3W条数据的时候,出现访问超时情况。

解决方法 :调整proxy_read_timeout,连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理
在ingress中添加注释

nginx.ingress.kubernetes.io/proxy-read-timeout: 600

这里需要注意的事该注释的value需要时number类型,不能加s,否则将不生效

总结

使用NGINX ingress controller的好处就是对于nginx配置相对比较熟悉,性能也不差。相关nginx配置的对应的ingress可以在 https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/annotations/ 上查到。

本页地址:

### Kubernetes DaemonSet 和 ingress-nginx配置与使用 #### 什么是 DaemonSet? DaemonSet 是一种控制器,用于确保集群中的每个节点运行一个 Pod 副本。如果向集群中添加新节点,则该节点也会获得 Pod 实例[^3]。 #### 使用 DaemonSet 部署 ingress-nginx 通过 DaemonSet 方式部署 ingress-nginx 可以使每个节点都拥有一个 ingress-nginx 控制器实例,从而提高高可用性和负载均衡能力。以下是具体操作: 1. **下载官方的 deploy 文件** 下载适用于云环境的标准部署文件并调整为适合本地使用的版本: ```bash wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.6.4/deploy/static/provider/baremetal/deploy.yaml ``` 2. **修改命名空间** 如果需要自定义命名空间,可以先创建一个新的命名空间: ```bash kubectl create namespace ingress-nginx ``` 然后编辑 `deploy.yaml` 文件,将所有涉及默认命名空间的部分替换为新的命名空间名称。 3. **应用配置** 应用 YAML 文件来启动 ingress-nginx: ```bash kubectl apply -f deploy.yaml ``` 4. **ConfigMap 自定义配置** ConfigMap 提供了灵活的方式来定制 Nginx 行为。可以通过以下命令查看当前存在的 ConfigMap: ```bash kubectl get cm -n ingress-nginx ``` 结果可能类似于以下内容: ``` NAME DATA AGE ingress-controller-leader-nginx 0 7d2h kube-root-ca.crt 1 7d2h nginx-configuration 0 7d2h tcp-services 0 7d2h udp-services 0 7d2h ``` 用户可以根据需求修改 `nginx-configuration` 中的内容。例如增加超时时间或其他高级设置[^1]。 5. **验证 Deployment 是否成功** 检查 Pods 运行状态以及 Service 是否正常工作: ```bash kubectl get pods,svc -n ingress-nginx ``` #### 示例:创建 Ingress 资源 假设已经有一个名为 `my-service` 的服务,并希望为其暴露外部访问路径 `/app`,则可编写如下 Ingress 定义: ```yaml apiVersion: networking.k8s.io/v1 kind: Ingress metadata: name: example-ingress spec: rules: - host: mydomain.example.com http: paths: - path: /app pathType: Prefix backend: service: name: my-service port: number: 80 ``` 执行以下命令将其应用于集群: ```bash kubectl apply -f ingress-example.yaml ``` #### Helm Chart 方法快速部署 除了手动方式外,还可以利用 Helm 工具简化部署流程。首先初始化 Helm 并添加仓库地址: ```bash helm repo add nginx-stable https://helm.nginx.com/stable helm repo update ``` 接着安装 ingress-nginx 到指定命名空间: ```bash helm install nginx-ingress nginx-stable/nginx-ingress --namespace nginx-ingress --create-namespace ``` --- ### 总结 以上介绍了如何借助 DaemonSet 来实现 ingress-nginx 的高可用部署方案及其基本配置方法[^3]。无论是采用原生 YAML 文件还是现代化工具如 Helm,都可以满足不同场景下的实际需求。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值