Docker,引用不同的容器。使用php命令调用mysqldump

joh*_*ohn 0 php mysql symfony docker docker-compose

我使用 Docker 在 Symfony3 项目上安装了一个数据库备份包 ( https://github.com/dizda/CloudBackupBundle ),但我无法让它工作,因为它找不到 PHP 或找不到 MySQL

当我php app/console --env=prod dizda:backup:start通过 exec、run 或通过 cron 运行时。我通过 PHP 映像收到 mysqldump 命令未找到错误,或从 Mysql/db 映像收到 PHP 未找到错误。

如何运行 php 命令,然后运行 ​​mysqldump 命令。

我的 docker-compose 文件如下:

version: '2'
services:
    web:
        # image: nginx:latest
        build: .
        restart: always
        ports:
            - "80:80"
        volumes:
            - .:/usr/share/nginx/html
        links:
            - php
            - db
            - node
        volumes_from:
            - php
        volumes:
            - ./logs/nginx/:/var/log/nginx
    php:
        # image: php:fpm
        restart: always
        build: ./docker_setup/php
        links:
            - redis
        expose:
            - 9000
        volumes:
            - .:/usr/share/nginx/html
    db:
        image: mysql:5.7
        volumes:
          - "/var/lib/mysql"
        restart: always
        ports:
            - 8001:3306
        environment:
          MYSQL_ROOT_PASSWORD: gfxhae671
          MYSQL_DATABASE: boxstat_db_live
          MYSQL_USER: boxstat_live
          MYSQL_PASSWORD: GfXhAe^7!
    node:
        # image: //digitallyseamless/nodejs-bower-grunt:5
        build: ./docker_setup/node
        volumes_from:
            - php
    redis:
        image: redis:latest
Run Code Online (Sandbox Code Playgroud)

我对 docker 还很陌生,所以你可以看到一些简单的改进,请随意标记...我正处于尝试和错误阶段!

pro*_*erq 5

包含代码的映像应该具有代码运行所需的所有依赖项。

在这种情况下,您的代码需要在本地安装 mysqldump 才能运行。我认为这是您的代码的依赖项。

将 RUN 行添加到 Dockerfile 中可能有意义,该行将安装 mysqldump 命令,以便您的代码可以使用它。

另一种方法是将数据库备份过程外部化,而不是将其留给您的应用程序。您可以有一些在 cron 上运行的容器,并以这种方式执行 mysqldump 过程。

我认为这两种方法都是干净的。