12

我的本地主机上有一个 docker 应用程序,它运行良好。我在上面运行 PHP、Nginx 和 Mariadb。

docker-compose.yml包含此代码的文件:

version: '3'

services:
    db:
      build:
        context: ./mariadb
      volumes:
          - "./.data/db:/var/lib/mysql"
          - "./logs/mariadb:/var/log/mysql"
      environment:
          MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}
          MYSQL_DATABASE: ${MYSQL_DATABASE}
          MYSQL_USER: ${MYSQL_USER}
          MYSQL_PASSWORD: ${MYSQL_PASSWORD}
      networks:
        - default
    php-fpm:
      build:
          context: ./php7-fpm
          args:
              TIMEZONE: ${TIMEZONE}
      volumes:
          - ${APP_PATH}:/var/www/app
      environment:
          DB_HOST: db
          DB_PORT: 3306
          DB_DATABASE: ${MYSQL_DATABASE}
          DB_USERNAME: ${MYSQL_USER}
          DB_PASSWORD: ${MYSQL_PASSWORD}
      depends_on:
        - db
      networks:
        - default
    nginx:
      build:
        context: ./nginx
        args:
          - 'php-fpm'
          - '9000'
      volumes:
        - ${APP_PATH}:/var/www/app
        - ./logs/nginx/:/var/log/nginx
      ports:
        - "80:80"
        - "443:443"
      depends_on:
        - php-fpm
      networks:
        - default
networks:
  default:
    driver: bridge

起初我以为只需要一个 compose 文件,当我构建镜像,将其推送到 docker hub,然后在我的生产服务器上拉取该镜像时,容器无法启动。

我做了一些阅读,有很多在线资源建议使用,从 1 到 4 个 docker 文件,并检查两个 git 分支......除此之外......

我知道我至少应该再创建一个名为 的文件docker-compose-prod.yml,并且在该文件中,我应该省略volumes:andport:属性,但似乎没有明确的指南:

  1. 如何让docker在本地工作

  2. 确切地何时以及如何构建生产容器。

有人可以帮我解决这个问题吗?

4

1 回答 1

9

建议您使用Multiple Compose files

使用多个 Compose 文件,您可以针对不同的环境或不同的工作流程自定义 Compose 应用程序。

接下来是一个例子:

(注意:接下来省略撰写文件的一些元素)

码头工人-compose.yml:

web:
  image: example/my_web_app:latest

码头工人-compose.dev.yml:

web:
  ports:
    - 80:80
  • Executedocker-compose -f docker-compose.yml -d将没有端口映射。
  • Executedocker-compose -f docker-compose.yml -f docker-compose.dev.yml -ddocker-compose.dev.yml覆盖一些docker-compose.yml使您的目标成为目标的值。

有关详细信息,请参阅docker doc,这是处理您的场景的官方建议,仅供参考。

更新:

您使用,因此无论在本地开发服务器或产品服务器中build: context: ./mariadb,compose 始终可以Dockerfile在要构建的文件夹中找到。mariadb

上面将在服务器devprod服务器上构建图像,这是您可以遵循的一个选项。

正如您在评论中所说的另一种选择:

但是在 prod 服务器上,我只能拉取并运行图像,并且必须事先使用 prod yml 文件构建图像

所以你可能不想在prod服务器上再次构建图像​​?

然后,接下来是一个更新的解决方案,只是一个例子:

码头工人-compose.yml:

db:
  image: your_maridb_image_name:your_maridb_image_version
  networks:
    - default

码头工人-compose.dev.yml:

db:
  build:
    context: ./mariadb
  ports:
    - "xxx:xxx"

码头工人-compose.prod.yml:

db:
  otheroptions_special_for_prod_just_a_example: xxx

1) 搬运工-compose -f 搬运工-compose.yml -f 搬运工-compose.dev.yml -d

这将结合为下一个:

db:
  image: your_maridb_image_name:your_maridb_image_version
  networks:
    - default
  build:
    context: ./mariadb
  ports:
    - "xxx:xxx"

根据docker-compose语法,如果可以build:context的话,compose 不会 docker 从 docker 注册表中拉取镜像,只需找到Dockerfilein context,最后构建一个具有您在 in 中指定的名称的镜像image,这里是your_maridb_image_name:your_maridb_image_version.

然后,您需要 push 它dockerhub,但您确实需要停止本地容器。

2) 搬运工-compose -f 搬运工-compose.yml -f 搬运工-compose.prod.yml -d

这将结合为下一个:

db:
  image: your_maridb_image_name:your_maridb_image_version
  networks:
    - default
  otheroptions_special_for_prod_just_a_example: xxx

根据docker-compose语法,build:context没有负担,所以 compose 会直接从远程注册表(docker hub) docker pull 镜像,还记得你在本地开发服务器上完成开发后将镜像推送到 dockerhub 吗?所以不需要再次构建图像​​。

于 2018-10-10T02:16:04.313 回答