nginx - 多个网站在Docker容器中运行,如何实现?

我正在使用以下docker-composer脚本运行两个Docker容器:

db:
  image: cofoundry/mysql
  environment:
    - MYSQL_USER=wordpress
    - MYSQL_PASS=wordpress
    - MYSQL_DB=wordpress
  ports:
    - "3306:3306"
  privileged: true

web:
  image: cofoundry/nginx-phpfpm
  volumes:
    - ../bedrock:/app
  environment:
    - DOCROOT=/app/web
  links:
    - db
  ports:
    - "80:80"
  privileged: true

但是我不确定如何在不同的站点(例如web_1,web_2等)上运行多个nginx-phpfpm Web容器?

或者,或者,如何在运行docker-composer的同时传播自定义nginx.conf,以便我可以在那里配置虚拟主机。

谢谢!

最佳答案

所以做到这一点的方法(正如我在评论中提到的那样)是使用类似autodock的方法:

示例:(基于您的docker-compose.yml):

db:
  image: cofoundry/mysql
  environment:
    - MYSQL_USER=wordpress
    - MYSQL_PASS=wordpress
    - MYSQL_DB=wordpress
  ports:
    - "3306:3306"
  privileged: true

web:
  image: cofoundry/nginx-phpfpm
  volumes:
    - ../bedrock:/app
  environment:
    - DOCROOT=/app/web
    - VIRTUALHOST=myapp.example.com
  links:
    - db
  privileged: true

autodock:
    image: prologic/autodock
    ports:
        - "1338:1338/udp"
        - "1338:1338/tcp"
    volumes:
        - /var/run/docker.sock:/var/run/docker.sock

autodockhipache:
    image: prologic/autodock-hipache
    links:
        - autodock
        - hipache:redis

hipache:
    image: hipache
    ports:
        - 80:80
        - 443:443

的唯一要求是为*.example.com设置一个通配符DNS条目,以指向您的“Docker主机”。例如:
*.example.com A 1.1.1.1

您可以在文章中阅读有关这一切的更多信息:

A Docker-based mini PaaS

这样就可以在“Docker Host”上运行的任意数量的网站上扩展和运行。

编辑:关于此设置的好处是,它很简单,它是自动化的,它只需要向要暴露给Web的容器中添加一个额外的环境变量,而只需要一个初始设置要求(通配符dns条目)。

https://stackoverflow.com/questions/29792466/

相关文章:

hadoop - 在实际运行oozie工作流之前如何检测错误?

hadoop - Hadoop 2.7.7,无法使用端口8088打开Resource Manager

apache-spark - Spark的示例在客户端模式下引发FileNotFoundExcept

ubuntu - docker登录错误: no such host

dns - 在链接的Docker容器中解析内部DNS

docker - docker 容器可以连接到 SRIOV 虚拟功能吗?

hadoop - 为什么 hive 中的CTAS查询没有得到预期的结果?

amazon-web-services - 需要有关数据管道创建的设计输入

sql - 配置单元确定日期重叠的记录

python - Fedora 22 : ERROR: No module named '_rpmb