如何使用NGINX在Docker中设置动态子域

时间:2019-04-12 08:19:03

标签: php docker nginx

基本上,我需要具有 动态子域 ,因此该站点应该可以在 Docker 中的任何子域中使用,如下所示:

admin.example.com adrian.example.com files.example.com

我没有固定数量的子域,所以我不能只将它们全部放入主机文件中。

Server_name也无济于事:server_name www.$hostname;

他们都应该指向同一个网站。 我已经尝试过 jwilder 反向代理,但是无法正确设置它。

我有一个docker-compose.ymlDockerfile

有人可以给我一个我可以使用的工作代码,然后根据需要进行更改。而且,如果我还需要更改主机文件。

我做了一些研究,但是我对nginx和docker的了解还不够。

Nginx.conf

server {
    server_name .example.local;

    listen 80 default;
    client_max_body_size 1008M;
    access_log /var/log/nginx/application.access.log;
    error_log  /var/log/nginx/error.log;
    root /application/web;
    index index.php;

    if (!-e $request_filename) {
        rewrite ^.*$ /index.php last;
    }

    location ~ \.php$ {
        fastcgi_pass php-fpm:9000;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PHP_VALUE "error_log=/var/log/nginx/application_php_errors.log";
        include fastcgi_params;
        fastcgi_buffers 16 16k;
        fastcgi_buffer_size 32k;
        proxy_buffer_size   128k;
        proxy_buffers   4 256k;
        proxy_busy_buffers_size   256k;
    }

}

Dockerfile

FROM phpdockerio/php73-fpm:latest

RUN mkdir /application
WORKDIR "/application"
COPY . /application

# Fix debconf warnings upon build
ARG DEBIAN_FRONTEND=noninteractive

RUN apt-get update                                                                                                  && \
    # Installing packages
    apt-get -y --no-install-recommends --assume-yes --quiet install                                                    \
    nano curl git ca-certificates ruby-dev gcc automake libtool rubygems build-essential make php-pear                 \
    php7.3-mysql php7.3-bcmath php-imagick php7.3-intl php7.3-gd php-yaml php7.3-soap php7.3-dev mysql-client       && \
    # Xdebug
    pecl install xdebug                                                                                             && \
    # Cleaning up after installation
    apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*

docker-compose.yml

version: "3.1"
services:

  db:
    image: mysql:5.6
    container_name: ls-db
    working_dir: /application
    volumes:
      - .:/application:cached      # User-guided caching
      - ./phpdocker/sql:/docker-entrypoint-initdb.d
    environment:
      MYSQL_DATABASE: ls
      MYSQL_USER: drupal
      MYSQL_PASSWORD: drupal
      MYSQL_ROOT_PASSWORD: root
    ports:
      - "6006:3306"
    networks:
      - ls

  web:
    image: nginx:alpine
    container_name: ls-webserver
    working_dir: /application
    volumes:
      - .:/application:cached      # User-guided caching
      - ./phpdocker/nginx/nginx.conf:/etc/nginx/conf.d/default.conf
    ports:
      - "6060:80"
    networks:
      - ls

  php-fpm:
    build: phpdocker/php-fpm
    container_name: ls-php-fpm
    working_dir: /application
    volumes:
      - .:/application:cached      # User-guided caching
      - ./phpdocker/php-fpm/php-ini-overrides.ini:/etc/php/7.3/fpm/conf.d/99-overrides.ini
    networks:
      - ls

networks:
  ls: # this network (app1)
    driver: bridge

volumes:
  db:

1 个答案:

答案 0 :(得分:1)

不确定您使用jwilder的反向代理尝试了什么,但失败了,但这是解决当前确切问题而无需处理nginx配置和复杂的compose配置的绝佳方法。

这是一个有效的代码,您甚至不必更改主机文件

version: '3.7'

services:
  nginx:
    image: jwilder/nginx-proxy
    ports: ["80:80"]
    volumes:
    - /var/run/docker.sock:/tmp/docker.sock:ro
    environment:
      DEFAULT_HOST: fallback.lvh.me

  api:
    image: dannyben/whoami
    environment:
      MESSAGE: I am the API
      VIRTUAL_HOST: "*.lvh.me"

  web:
    image: dannyben/whoami
    environment:
      MESSAGE: I am the WEB
      VIRTUAL_HOST: "www.lvh.me"

为了使其工作,必须首先启动nginx代理:

$ docker-compose up -d nginx

只有这样,后端服务

$ docker-compose up -d api web

然后,您可以访问www.lvh.me来查看Web后端,并访问anything-else.lvh.me来查看API后端。

此外,您可以为VIRTUAL_HOST环境变量提供多个通配符主机,以便它既支持本地开发环境又支持生产环境,如下所示:

VIRTUAL_HOST: "*.lvh.me,*.your-real-domain.com"

请务必注意,为了使其在生产环境中正常工作,还应该将DNS设置为使用通配符子域。

在此演示中,lvh.me只是将所有流量转发到127.0.0.1,后者又到达您的nginx,后者再将流量向内转发到您的实际应用程序。