Express Nginx 502 Bad Gateway 排错

本文介绍了解决服务器使用pm2和Node.js进程工具启动Express应用时出现502 Bad Gateway错误的方法。通过检查Nginx配置及Express绑定端口的一致性,最终修复了curl本地请求被拒绝的问题。

问题描述

在服务器使用 pm2 nodejs进程工具启动express服务器,在浏览器使用get请求时出现:

502 Bad Gateway

在服务器终端使用curl 模拟本地请求请求被拒绝

curl: (7) Failed to connect to localhost :Connection refused

转发端口检查

Nginx服务器配置是否绑定Express服务的端口.
检查 nginx 配置,可以看到nginx转发本地端口为8765。
在这里插入图片描述

列出连接端口列表

netstat -nptl
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      -               
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      -               
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      -               
tcp        0      0 0.0.0.0:443             0.0.0.0:*               LISTEN      -               
tcp6       0      0 :::80                   :::*                    LISTEN      -               
tcp6       0      0 :::22                   :::*                    LISTEN      -               
tcp6       0      0 :::3000                 :::*                    LISTEN      -  

可以看到列表中没有目标8765端口。
于是检查Express的配置文件发现Express绑定端口与Nginx的不符,执行修改。

// vim /home/express/bin/www
/**
 * Get port from environment and store in Express.
 */
var port = normalizePort(process.env.PORT || '8765');
app.set('port', port);
/**
 * Create HTTP server.
 */

请求恢复正常 。


其他nginx配置 ⚠️

server {
    listen 0.0.0.0:80;
    server_name localhost;
    access_log /var/log/nginx/nodetest.log;

    location / {
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header Host $http_host;
      proxy_set_header X-NginX-Proxy true;

      proxy_pass http://node/;
      proxy_redirect off;
    }
}

upstream node {
    server 127.0.0.1:8080;
}

修改完成之后 nginx -s reload || service nginx restart

 # proxy_pass http://node/;
   proxy_pass http://node;
### Nginx 502 Bad Gateway 错误的解决方案 Nginx 报告 `502 Bad Gateway` 错误通常是由于上游服务器未能正常响应请求引起的。以下是详细的分析和解决方法: #### 日志排查 当遇到 `502 Bad Gateway` 错误时,首要任务是检查 Nginx 的错误日志文件。默认情况下,该文件位于 `/var/log/nginx/error.log` 路径下[^1]。如果不确定具体位置,可以查阅 Nginx 配置文件(通常为 `/etc/nginx/nginx.conf`),寻找 `error_log` 指令来确认实际路径。 通过实时监控日志输出,可快速捕获具体的错误原因。例如,执行以下命令以动态跟踪日志更新: ```bash tail -f /var/log/nginx/error.log ``` 常见的错误记录可能包括权限不足或缓冲区设置不当等问题。例如,日志中可能出现类似以下的内容: - 权限拒绝:`connect() to 192.168.0.204:2828 failed (13: Permission denied)` 表明连接到后端服务失败,可能是防火墙阻止或 SELinux 设置不正确所致[^1]。 - 缓冲区过小:`upstream sent too big header while reading response header from upstream` 提示返回头数据超出当前配置允许的最大大小[^2]。 --- #### 解决方案一:调整缓冲区参数 对于因缓冲区不足引发的 `502 Bad Gateway` 错误,可通过修改 Nginx 配置文件中的相关参数加以优化。编辑配置文件(如 `/etc/nginx/nginx.conf` 或站点特定配置文件),添加或调整以下指令: ```nginx http { proxy_buffer_size 128k; proxy_buffers 4 256k; proxy_busy_buffers_size 256k; fastcgi_buffer_size 128k; fastcgi_buffers 4 256k; fastcgi_busy_buffers_size 256k; } ``` 这些参数用于增大代理缓存区域的容量,从而减少因头部信息过大而导致的错误发生概率[^2]。 完成更改后需重新加载 Nginx 配置才能生效: ```bash sudo systemctl reload nginx ``` --- #### 解决方案二:修复网络通信问题 若错误源于无法成功建立与后端服务之间的连接,则应重点核查以下几个方面: 1. **IP 地址和端口验证**:确保 Nginx 中指定的后端地址和服务监听端口号匹配无误; 2. **防火墙规则检查**:临时禁用防火墙测试连通性,或者针对目标主机开放必要的入站流量; 3. **SELinux 状态评估**:启用强制模式下的 Linux 安全增强功能可能导致意外行为;尝试切换至宽容模式观察效果变化。 --- #### 解决方案三:重启关联组件 有时简单的重启操作即可消除瞬态故障带来的影响。依次停止并启动涉及的服务实例,比如 PHP-FPM 和 MySQL 数据库引擎等依赖项。注意遵循正确的顺序以免引起连锁反应。 最后再次提醒大家养成良好的习惯——定期备份重要资料以及密切监视运行状况指标! --- ### 总结 综上所述,处理 Nginx 出现的 “502 Bad Gateway” 故障需要从多个角度入手逐一排除潜在隐患点。优先审阅 error log 获取初步线索之后再针对性采取措施予以纠正才是明智之举。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值