gpt4 book ai didi

kubernetes - NGINX 入口 Controller 在 60 秒后超时请求

转载 作者:行者123 更新时间:2023-12-03 09:42:44 24 4
gpt4 key购买 nike

当一个请求需要超过 60 秒来响应时,入口 Controller 似乎会反弹

从我可以看到我们的 NGINX 入口 Controller 在处理一个请求超过 60 秒后返回 504 给客户端。我可以从 NGINX 日志中看到这一点:

2019/01/25 09:54:15 [error] 2878#2878: *4031130 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 10.244.0.1, server: myapplication.com, request: "POST /api/text HTTP/1.1", upstream: "http://10.244.0.39:45606/api/text", host: "myapplication.com"
10.244.0.1 - [10.244.0.1] - - [25/Jan/2019:09:54:15 +0000] "POST /api/text HTTP/1.1" 504 167 "-" "PostmanRuntime/7.1.6" 2940 60.002 [default-myapplication-service-80] 10.244.0.39:45606 0 60.000 504 bdc1e0571e34bf1223e6ed4f7c60e19d

第二个日志项显示 上游响应时间 请求时间 的 60 秒(参见 NGINX log format here )

但是我在入口配置中将所有超时值指定为 3 分钟:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: aks-ingress
annotations:
kubernetes.io/ingress.class: nginx
certmanager.k8s.io/cluster-issuer: letsencrypt
nginx.ingress.kubernetes.io/rewrite-target: /
nginx.ingress.kubernetes.io/send_timeout: "3m"
nginx.ingress.kubernetes.io/proxy-connect-timeout: "3m"
nginx.ingress.kubernetes.io/proxy-read-timeout: "3m"
nginx.ingress.kubernetes.io/proxy-send-timeout: "3m"
spec:
tls:
- hosts:
- myapplication.com
secretName: tls-secret
rules:
- host: myapplication.com
http:
paths:
- path: /
backend:
serviceName: myapplication-service
servicePort: 80

我错过了什么?

我在 Azure (AKS) 上使用 nginx-ingress-1.1.0 和 k8s 1.9.11。

最佳答案

该问题已通过为这些注释提供的整数值(以秒为单位)得到解决:

nginx.ingress.kubernetes.io/proxy-connect-timeout: "180"
nginx.ingress.kubernetes.io/proxy-read-timeout: "180"
nginx.ingress.kubernetes.io/proxy-send-timeout: "180"

看来 this variation NGINX 入口 Controller 需要这样。

关于kubernetes - NGINX 入口 Controller 在 60 秒后超时请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54366082/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com