如何解决我的 NodeJS 应用程序无缘无故地显示 502 错误
我的 digitalocean droplet 有一个非常大的问题,你能帮我吗,
我有一个 nodeJS 应用程序,它与 MySQL 一起工作,我使用 Nginx + Ubuntu
但无缘无故,我收到了 502 坏网关
我已经升级了我的 Droplet,3 天后我的应用又关闭了
但在我的 digitalocean 平台上真的很奇怪,CPU % 和内存都很好
现在我已经将我的 droplet 升级到了最后一个包
你能帮我吗
当我执行这个命令时 sudo tail -30 /var/log/nginx/error.log
我遇到了这个错误
[error] 989#989: *6611 connect() failed (111: Connection refused) while connecting to upstream,client:
我想说明的是,我的应用已经运行了 1 年多
这是nginx代码
server {
root /var/www/html;
index index.html index.htm index.nginx-debian.html;
server_name domain.app;
location / {
proxy_pass http://localhost:3001;
proxy_http_version 1.1;
proxy_set_header HTTP_X_FORWARDED_FOR $remote_addr;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
listen 443 ssl; # managed by Certbot
ssl_certificate /etc/letsencrypt/live/domain.app/fullchain.pem; # managed by Certbot
ssl_certificate_key /etc/letsencrypt/live/domain.app/privkey.pem; # managed by Certbot
include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}
server {
if ($host = domain.app) {
return 301 https://$host$request_uri;
} # managed by Certbot
server_name domain.app;
listen 80;
return 404; # managed by Certbot
}
感谢您的帮助
解决方法
我在使用 NodeJS (express) 和 Application Load Balancer (AWS) 时遇到了类似的问题。问题出在保持活动超时配置中,NodeJS 应用程序的默认超时设置为比负载均衡器上配置的超时更短的时间,这导致服务器在请求中间断开连接(由负载均衡器生成) ).
一个简单的修复是将 server.keepAliveTimeout
设置为比负载均衡器上配置的数字更高的数字。这是great post that helped me and it goes into much details