nginx error: upstream prematurely closed connection while reading response header from upstream(示例代码

Posted xinpureZhu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx error: upstream prematurely closed connection while reading response header from upstream(示例代码相关的知识,希望对你有一定的参考价值。

本篇文章由:http://xinpure.com/nginx-error-upstream-prematurely-closed-connection-while-reading-response-header-from-upstream/

环境描述

nginx 版本 1.10.2

php 版本 7.0.12

Node 版本 5.9.0

本文是想讲一个 Nginx 的错误,为啥还要提及 PHP 和 Node 的版本呢?容我先还原一下应用场景

首先就是我有一个绑定在 3000 端口的 Node Server

我需要从 80 端口直接访问这个服务,所以我使用了 Nginx 的反向代理

而至于 PHP ,其实这个错误就是与它有关

查找错误原因

当我使用这个 Node Server 的时候,返回了一个 502 Bad Gateway 错误

查看网络请求,也没有什么错误,接着就查看了 Nginx error log 里的错误信息

[error] 17028#0: *111 upstream prematurely closed connection while reading response header from upstream

好吧,并不是什么明显的错误提示,只好到 Google 查查看了

查了一番似乎也挺多人遇到这个问题的,但是解决问题的方法好像都不一样。。。

有的说是 keepalive_timeout 值太小了 (这个值我根据服务配置,已经改成 600,感觉不太可能),还有说重启 Nginx 就行了 (尝试过。),等等。。。

当然也有让我眼前一亮的答案,那就是 重启 php-fpm ,果断尝试一下

果然。。。启动报错了,提示大概意思是端口被占用了,瞬间感觉好像找对了突破口

解决错误

看了一下端口才发现,原来是之前已经开启了另外一个 Node Server 占用了 php-fpm 默认的 9000 端口

简直是自己坑自己!

因为服务的端口不能改,要和其它同事的统一,所以我把 php-fpm 的端口改成了 9999

PHP 是使用 brew 安装的,配置路径为: /usr/local/etc/php/7.0/php-fpm.d/www.conf

listen = 127.0.0.1:9999

然后重启 php-fpm 就 OK 了

以上是关于nginx error: upstream prematurely closed connection while reading response header from upstream(示例代码的主要内容,如果未能解决你的问题,请参考以下文章

[error] [nginx+uwsgi] upstream prematurely closed connection while reading response header from ups

[error] [nginx+uwsgi] upstream prematurely closed connection while reading response header from ups

configure-nginx-how-to-handle-500-error-on-upstream-itself-while-nginx-handle

nginx proxy_next_upstream模块 重复提交问题

Nginx" upstream prematurely closed connection while reading response header from upstream"

nginx 报错 upstream timed out (110: Connection timed out)解决方案