0

我的 digitalocean droplet 有一个非常大的问题,您能帮帮我吗?

我有一个 nodeJS 应用程序,它与 MySQL 一起使用,我使用 Nginx + Ubuntu

但无缘无故,我得到了 502 bad gateway

我已经升级了我的 Droplet,3 天后我的应用再次关闭

但是在我的 digitalocean 平台上,CPU % 和内存真的很奇怪

现在我已将我的液滴升级到最后一个包

你能帮我吗

当我执行这个命令时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


}

感谢您的帮助

4

1 回答 1

1

我在 NodeJS (express) 和 Application Load Balancer (AWS) 上遇到了类似的问题。问题出在保持活动超时配置中,NodeJS 应用程序默认超时设置为比负载均衡器上配置的超时更短的时间,这导致服务器在请求中间断开连接(由负载均衡器产生) )。

一个简单的解决方法是将 设置server.keepAliveTimeout为高于负载平衡器上配置的数字。这是一篇对我有帮助的很棒的帖子,它涉及到很多细节

nginx 的默认保活时间为75 秒;NodeJS 的默认保持活动状态是5 秒。

于 2021-05-09T20:08:43.117 回答