Docker Nginx停止了:[emerg] 1#1:在上游找不到主机

问题描述 投票:11回答:3

我在ECS服务器上运行docker-nginx。我的nginx服务突然停止,因为其中一个服务器的proxy_path无法访问。错误如下:

[emerg] 1#1: host not found in upstream "dev-example.io" in /etc/nginx/conf.d/default.conf:988

我的配置文件如下:

 server {
       listen      80;
       server_name     test.com;
       location / {
          proxy_pass         http://dev-exapmle.io:5016/;
          proxy_redirect     off;

          ##proxy_set_header   Host             $host;
          proxy_set_header   X-Real-IP        $remote_addr;
          proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;

          client_max_body_size       10m;
          client_body_buffer_size    128k;

          proxy_connect_timeout      90;
          proxy_send_timeout         90;
          proxy_read_timeout         90;

          proxy_buffer_size          4k;
          proxy_buffers              4 32k;
          proxy_busy_buffers_size    64k;
          proxy_temp_file_write_size 64k;
       }
}

server {
   listen       80 default_server;
   server_name  localhost;

   #charset koi8-r;
   #access_log  /var/log/nginx/log/host.access.log  main;

   location / {
      root   /usr/share/nginx/html;
      index  index.html index.htm;
   }

   #error_page  404              /404.html;

   # redirect server error pages to the static page /50x.html
   #
   error_page   500 502 503 504  /50x.html;
   location = /50x.html {
      root   /usr/share/nginx/html;
   }
}

我在配置文件中有很多服务器,即使一台服务器出现故障,我也需要运行nginx。有什么办法可以解决吗?

任何解决这个问题的建议都将不胜感激。

nginx docker amazon-ecs
3个回答
5
投票

如果您的站点已关闭,请包括防止Nginx崩溃,包括解析器指令,如下所示:

 server {
       listen      80;
       server_name     test.com;
       location / {
          resolver 8.8.8.8
          proxy_pass         http://dev-exapmle.io:5016/;
          proxy_redirect     off;
 ...

警告!使用公共DNS会在后端造成安全风险,因为您的DNS请求可能会被欺骗。如果这是一个问题,您应该将解析器指向安全的DNS服务器。


5
投票

在我的情况下,添加解析器并没有解决问题。但我能够通过为主机使用变量来解决它。此外,我想在127.0.0.11使用Docker的DNS更有意义(这是一个固定的IP)。

例:

server {
  listen 80;
  server_name test.com;

  location / {
    resolver 127.0.0.11;
    set example dev-example.io:5016
    proxy_pass http://$example;
  }
}

我在this page上找到了变量解决方法。


3
投票

这通常意味着您作为上游服务器提供的DNS名称无法解析。要测试它,请登录nginx服务器并尝试ping所提供的上游服务器并查看名称解析是否正确完成,如果它的docker容器尝试使用docker exec -it获取shell,则尝试ping上游以测试名称解析。如果contianer已停止,请尝试在服务器块中使用IP地址而不是dns名称。

proxy_pass         http://<IP ADDRESS>:5016/;

如果要为此位置使用与主机系统不同的dns服务器,也可以使用解析程序指令:

resolver 8.8.8.8;
© www.soinside.com 2019 - 2024. All rights reserved.