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 还很陌生,所以你可以看到一些简单的改进,请随意标记...我正处于尝试和错误阶段!
包含代码的映像应该具有代码运行所需的所有依赖项。
在这种情况下,您的代码需要在本地安装 mysqldump 才能运行。我认为这是您的代码的依赖项。
将 RUN 行添加到 Dockerfile 中可能有意义,该行将安装 mysqldump 命令,以便您的代码可以使用它。
另一种方法是将数据库备份过程外部化,而不是将其留给您的应用程序。您可以有一些在 cron 上运行的容器,并以这种方式执行 mysqldump 过程。
我认为这两种方法都是干净的。