php - symfony 第一次无法安装资源

标签 php mysql symfony docker docker-compose

我尝试使用 docker compose 安装数据库和 Web 服务器。

我的 docker-compose 文件是:

version: '3.3'
services:
  db:
    image: pix_db
    container_name: pix_db
    image: mysql:5.7
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: test
      MYSQL_DATABASE: test
      MYSQL_USER: test
      MYSQL_PASSWORD: test
    networks:
    - backend
  api:
    image: pix_api
    container_name: pix_api
    build:
      context: .
      dockerfile: ./Dockerfiles/api/Dockerfile.cpu
    depends_on:
    - media
    - db
    ports:
    - "8080:8080"
    networks:
    - backend

networks:
  backend:
  hidden:

volumes:
  db_data:

当我到达 docker 文件中的这一行时:

php bin/console assets:install -e prod

它崩溃并出现几个错误,例如:

  [Doctrine\DBAL\Exception\ConnectionException]
  An exception occured in driver: SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Name or service not known

当我从之前的行构建容器时: 命令 php bin/console assets:install -e prod 在我第一次调用它时崩溃并出现相同的错误。 但第二次成功了:

Installing assets as hard copies.

--- ----------------------------- ----------------
      Bundle                        Method / Error
--- ----------------------------- ----------------
  ✔   NelmioApiDocBundle            copy
      -> web/bundles/nelmioapidoc
  ✔   AppBundle                     copy
      -> web/bundles/app
--- ----------------------------- ----------------

! [NOTE] Some assets were installed via copy. If you make changes to these assets you have to run this command again.


[OK] All assets were successfully installed.

最佳答案

您的问题是您在镜像构建过程中尝试访问数据库。每个镜像都是单独构建的,当镜像创建时,它无法访问任何正在运行的服务,例如 mysql DB 或任何其他服务。

因此,如果您使用类似 php bin/console assets:install -e prod 的内容来连接到数据库,那么它将无法工作。您需要以不调用数据库的方式执行命令,或者需要将命令延迟到容器启动。

例如,如果您查看 mysql 镜像。它不会在构建期间初始化数据库。它也使用 docker-entrypoint.sh 在容器启动时构建空白数据库。请参阅下面的链接

https://github.com/docker-library/mysql/blob/0590e4efd2b31ec794383f084d419dea9bc752c4/5.7/docker-entrypoint.sh

因此,您需要遵循类似的方法并创建一个 entrypoint.sh 脚本,该脚本将在容器启动后运行,并为您构建这些 Assets 和其他内容。您还需要确保在运行命令之前 mysql 容器已完全启动并准备好接受数据库连接。

我通常在初始化之前添加 sleep 15 左右。但您可以使用类似 https://github.com/vishnubob/wait-for-it 的内容还有。

关于php - symfony 第一次无法安装资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46079775/

相关文章:

php - php脚本中最佳的MYSQL查询数是多少?

php - 尝试命名我的模型时找不到类 'Models\Eloquent'

java - 如何配置 spring boot 应用程序以在 MySQL 上使用 SSL/TLS?

Symfony 4 - 将构造函数参数注入(inject) Autowiring 的第三方服务

php - JSON 模块可能已安装,但 json_encode() 不存在

php - Laravel 表单 HTTPS Action

php - 如何在 JavaScript 中显示 MySQL 中 "onclick"的下一个结果?

php - 忽略主键重复

PHPExcel:写入期间无法使用缓存

php - Symfony2 在导航中获取用户名