upstream sent invalid chunked response while reading upstream

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zouheliang/article/details/80244670

再使用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类型请求了。


猜你喜欢

转载自blog.csdn.net/zouheliang/article/details/80244670