Docker撰写和Nginx网络主机名

时间:2020-04-07 17:27:00

标签: docker nginx docker-compose docker-networking docker-network

我具有以下配置:

  • nginx由充当反向代理的docker compose文件// // SSL端点
  • 启动
  • 由另一个docker启动的应用程序服务(出于模块化原因)组成为应用程序提供服务的文件
  • reverse_proxyapp_service通过app_network
  • 连接

由于它们是通过app_network连接的,所以我可以像app_service这样在nginx配置中访问http://app_service:8080,这很好,因为我不需要公开端口应用程序服务本身。

不幸的是,直到我调出应用服务容器,nginx才启动,因为它在启动时会检查主机名app_service的存在。

如何防止nginx在启动时检查主机名,可能在Bad Gateway尚未运行时尝试连接时导致app_service错误?

供参考的配置文件:

# reverse proxy docker-compose.yml
version: '3'
services:
  reverse_proxy:
    restart: always
    container_name: reverse_proxy
    image: nginx
    ports:
      - 80:80
      - 443:443
    volumes:
      - /srv/docker/nginx/config:/etc/nginx
      - /srv/ssl:/srv/ssl

    networks:
  default:
    external:
      name: app_network
# application service docker-compose.yml
version: '3'

services:
  app_service:
    restart: always
    container_name: app_service
    image: <my_app_image>

networks:
  default:
    external:
      name: app_network
# nginx config
server {

    listen 443 ssl http2;
    listen [::]:443 ssl http2;

    server_name app.example.com;

    location / {
        proxy_pass http://app_service:8080;
        include proxy.conf;
    }
    ssl_certificate /srv/ssl/<mycert>.crt;
    ssl_certificate_key /srv/ssl/<mykey>.key;
}

1 个答案:

答案 0 :(得分:0)

这是为我工作的一种方式:



    # nginx config
    server {

        listen 443 ssl http2;
        listen [::]:443 ssl http2;

        server_name app.example.com;

        location / {
            set $upstream app_service:8080;

            proxy_pass $upstream;
            include proxy.conf;
        }
        ssl_certificate /srv/ssl/.crt;
        ssl_certificate_key /srv/ssl/.key;
    }

如果主机不可用,并且在启动时不检查可用性,则会显示一条502 Bad Gateway消息。