upstream sent invalid chunked response while reading upstream

再使用nginx的过程中,想通过nginx转发一个请求,并根据请求的结果返回,进行是否需要缓存。

方案一,用nginx+lua

      当时想的是lua有脚本功能,利用lua将结果取出并将结果缓存再nginx中,最终结果是取到了,但是没法缓存,原因是nginx早就执行完成了,人家该缓存的就缓存好了,你再怎么折腾结果也不会改变原有结果,顺便附上lua各个不中的生命周期顺序。从结果上也可以看出body_filter_by_lua的时候已经无能为力了。大家耗的想法可以讨论。

方案二  用nginx +微服务代理(直接改响应,从而实现)

这种方案理论上可行,但是也遇到了不少坑,nginx的缓存设置一般是通过http状态来的,其实他还有很多约束,比如标题错误,就是我在微服务中返回了一个RestTemplate.getForEntity 的返回值ResponseEntity对象,这都是小问题,直接转成json以字符串形式返回就没有问题了,后来还遇到了post请求的时候无法缓存,只有get类型的才能缓存,当然我看到HTTP版本是不一致的POST是HTTP/1.0, GET是HTTP/1.1,这里我没有深究是HTTP协议导致的还是请求类型导致的,反正用GET HTTP/1.1是没有问题的,最终把请求修改后OK。

追加:POST 或者GET不是关键,增加proxy_cache_methods GET HEAD POST; 就可以缓存post类型请求了。


以下是使用Helm安装GitLab的步骤: 1. 添加GitLab Helm仓库 ```shell helm repo add gitlab https://charts.gitlab.io ``` 2. 创建GitLab命名空间 ```shell kubectl create namespace gitlab ``` 3. 为GitLab创建一个values.yaml文件,其中包含必要的配置选项。例如: ```yaml global: edition: ce minio: enabled: false postgresql: install: true postgresUser: gitlab postgresPassword: gitlab postgresDatabase: gitlabhq_production redis: install: true certmanager-issuer: email: you@example.com ingress: configureCertmanager: true annotations: kubernetes.io/ingress.class: nginx nginx.ingress.kubernetes.io/proxy-body-size: "0" nginx.ingress.kubernetes.io/proxy-read-timeout: "600" nginx.ingress.kubernetes.io/proxy-send-timeout: "600" nginx.ingress.kubernetes.io/ssl-redirect: "true" nginx.ingress.kubernetes.io/force-ssl-redirect: "true" nginx.ingress.kubernetes.io/secure-backends: "true" nginx.ingress.kubernetes.io/backend-protocol: "HTTPS" nginx.ingress.kubernetes.io/proxy-buffering: "on" nginx.ingress.kubernetes.io/proxy-buffer-size: "16k" nginx.ingress.kubernetes.io/proxy-buffers-number: "4" nginx.ingress.kubernetes.io/proxy-request-buffering: "on" nginx.ingress.kubernetes.io/proxy-request-buffer-size: "16k" nginx.ingress.kubernetes.io/proxy-response-buffering: "on" nginx.ingress.kubernetes.io/proxy-response-buffer-size: "16k" nginx.ingress.kubernetes.io/proxy-send-timeout: "600" nginx.ingress.kubernetes.io/proxy-read-timeout: "600" nginx.ingress.kubernetes.io/proxy-connect-timeout: "75" nginx.ingress.kubernetes.io/proxy-next-upstream: "error timeout invalid_header http_500 http_502 http_503 http_504" nginx.ingress.kubernetes.io/rewrite-target: /$2 nginx.ingress.kubernetes.io/configuration-snippet: | proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Host $host; proxy_set_header X-Forwarded-Ssl on; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_http_version 1.1; client_max_body_size 0; chunked_transfer_encoding on; gitlab: webservice: ingress: enabled: true annotations: nginx.ingress.kubernetes.io/ssl-redirect: "true" nginx.ingress.kubernetes.io/force-ssl-redirect: "true" nginx.ingress.kubernetes.io/rewrite-target: /$2 nginx.ingress.kubernetes.io/configuration-snippet: | proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Forwarded-Host $host; proxy_set_header X-Forwarded-Ssl on; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_http_version 1.1; client_max_body_size 0; chunked_transfer_encoding on; hosts: - host: gitlab.example.com paths: - path: /gitlab(/|$)(.*) backend: serviceName: gitlab-webservice servicePort: http ``` 4. 安装GitLab ```shell helm upgrade --install gitlab gitlab/gitlab \ --namespace=gitlab \ --set gitlab-runner.install=true \ --set gitlab-runner.certsSecretName=gitlab-runner-certs \ --reuse-values \ -f values.yaml ``` 请注意,这里的values.yaml文件中的配置选项仅供参考,您需要根据自己的需求进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值