首页 > 解决方案 > 通过 docker 容器的数据库连接问题

问题描述

我已经通过 docker 使用 Symfony 和 MariaDB 建立了一个开发环境。

我在那里拍摄了 bitman/symfony 图像:

 https://hub.docker.com/r/bitnami/symfony

这是我的 docker-compose.yaml

version: '2'

services:
  myapp:
    image: 'bitnami/symfony:1'
    ports:
      - '8000:8000'
    volumes:
      - '.:/app'
    environment:
      - SYMFONY_PROJECT_NAME=backend
      - MARIADB_PORT_NUMBER=3306
      - MARIADB_USER=root
    container_name: symfony_container
    depends_on:
      - mariadb
  mariadb:
    image: 'bitnami/mariadb:10.3'
    ports:
      - '3306:3306'
  environment:
    - ALLOW_EMPTY_PASSWORD=yes
    - MARIADB_USER=root
  container_name: mariadb_container

.env 文件中的重要行:

DATABASE_URL=mysql://root:@localhost:3306/

我的学说.yaml文件:

doctrine:
  dbal:
      url: '%env(resolve:DATABASE_URL)%'
      server_version: '5.7'
  orm:
      auto_generate_proxy_classes: true
      naming_strategy: doctrine.orm.naming_strategy.underscore_number_aware
      auto_mapping: true
      mappings:
          App:
              is_bundle: false
              type: annotation
              dir: '%kernel.project_dir%/src/Entity'
              prefix: 'App\Entity'
              alias: App

现在如果我运行docker-compose up,两个容器都会启动并且我可以访问 Symfony。

但是如果我尝试创建一个实体:

php bin/console make:entity

我收到以下四个错误:

An exception occurred in driver: SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Temporary failure in name resolution

SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Temporary failure in name resolution 

SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Temporary failure in name resolution  

PDO::__construct(): php_network_getaddresses: getaddrinfo failed: Temporary failure in name resolution 

奇怪的是,我可以通过 dbeaver 访问 MariaDB 数据库,没有任何问题。Symfony 容器似乎没有找到 MariaDB 容器。

我会准确地说我使用 symfony 版本 5.0.4

如果有人知道这些错误来自哪里,我将不胜感激

标签: mysqldockersymfonydoctrine-ormmariadb

解决方案


DATABASE_URL=mysql://root: @localhost :3306/

在 docker 的上下文中,localhost是当前正在运行的容器。由于这是从您的 symfony 容器中使用的,它会尝试在那里找到数据库。

从您的docker-compose.yml文件中,您的 db 服务被命名mariadb,并将从参与您的应用程序默认网络的容器中解析:

DATABASE_URL=mysql://root:@mariadb:3306/

注意:我怀疑一旦连接修复,您可能还有其他与数据库用户设置相关的问题需要解决。如果是这种情况,请仔细查看您的数据库映像配置文档


推荐阅读