繁体   English   中英

如果服务在启动时未准备好,Nginx 返回 502

[英]Nginx returns 502 if service not ready on start

我正在研究用 Raspberry Pi 构建的网络摄像头。 它具有以下组件:

  • 端口 3000 上的 Node.js
  • 端口 8090 上的 FFmpeg / FFserver
  • 前面的 Nginx 通过端口 80/443 (HTTP/HTTPS) 将这些服务代理在一起

我遇到的问题是,如果 Nginx 启动时 FFserver 未在端口 8090 上完全准备好,即使流正在运行,它也会持续为stream.mjpeg返回 502 。 就好像 Nginx 确定主机不存在然后再也不尝试一样。 一旦我重新启动/重新加载 Nginx 配置,它就会再次开始工作。

为什么会发生这种情况? 是否有我缺少的重试条件?

这是 Nginx 的配置:

server {
  listen 80;
  rewrite ^ https://$host$request_uri? permanent;
}

server {
  listen 443 ssl;

  ssl_certificate /etc/nginx/ssl/nginx.crt;
  ssl_certificate_key /etc/nginx/ssl/nginx.key;

  location / {
    proxy_pass http://localhost:3000;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_next_upstream error timeout http_502;

    # Basic auth
    auth_basic "Restricted";
    auth_basic_user_file /etc/nginx/htpasswd;
  }

  location /stream.mjpeg {
    proxy_pass http://localhost:8090/stream.mjpeg;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_next_upstream error timeout http_502;

    # Basic auth
    auth_basic "Restricted";
    auth_basic_user_file /etc/nginx/htpasswd;
  }
}

查看/var/log/nginx/error.log的 Nginx 日志后,我可以看到请求将发送到 IPv6 环回地址而不是 IPv4。 我将localhost更改为127.0.0.1并解决了问题。 为什么这会在重新启动 Nginx 后而不是之前起作用,对我来说仍然是个谜。

  location / {
    proxy_pass http://127.0.0.1:3000;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_next_upstream error timeout http_502;

    # Basic auth
    auth_basic "Restricted";
    auth_basic_user_file /etc/nginx/htpasswd;
  }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM