symfony无法首次安装资产

gk7wooem  于 2023-10-24  发布在  其他
关注(0)|答案(2)|浏览(84)

我试着用Docker compose安装一个DB和一个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.
gstyhher

gstyhher1#

你的问题是你试图在镜像构建过程中访问数据库。每个镜像都是单独构建的,当镜像被构建时,它不能访问任何正在运行的服务,比如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脚本,该脚本将在容器启动后运行,它将为您构建这些资产和其他内容。您还需要确保在运行命令之前,mysql容器已完全启动并准备好接受DB连接。
我通常在初始化前添加sleep 15左右,但你也可以使用类似https://github.com/vishnubob/wait-for-it的东西。

jum4pzuy

jum4pzuy2#

虽然前面的答案仍然是正确的,但还有另一个选项:在配置中设置服务器版本。如果没有设置,Symfony(更确切地说是Doctrine\DBAL)会尝试连接到您的数据库,以了解使用的服务器版本。

# config/packages/doctrine.yaml
doctrine:
    dbal:
        url: '%env(resolve:DATABASE_URL)%'

        # IMPORTANT: You MUST configure your server version,
        # either here or in the DATABASE_URL env var (see .env file)
        server_version: 'mariadb-10.9.4'

请阅读Symfony SDK中有关DBAL的配置参考。
另见https://github.com/kriswallsmith/assetic/issues/681#issuecomment-65768410

相关问题