Docker-PHP / MySQL-php_network_getaddresses:getaddrinfo失败:名称或服务未知

时间:2019-10-07 11:05:42

标签: mysql docker symfony docker-compose

我有以下docker-compose.yml,主要是从某些教程(https://medium.com/@romaricp/the-perfect-kit-starter-for-a-symfony-4-project-with-docker-and-php-7-2-fda447b6bca1)中复制的:

version: '3'
services:
  apache:
    build: .docker/apache
    container_name: sf4_apache
    ports:
      - 80:80
      - 443:443
    volumes:
      - .docker/config/vhosts:/etc/apache2/sites-enabled
      - .:/home/wwwroot/sf4:cached
    depends_on:
      - php

  mysql:
    image: mysql:5.7
    container_name: sf4_mysql
    command: "--default-authentication-plugin=mysql_native_password"
    restart: always
    ports:
      - 3306:3306
    volumes:
      - .docker/data/db:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: sf4
      MYSQL_USER: sf4
      MYSQL_PASSWORD: sf4

  php:
    build: .docker/php
    container_name: sf4_php
    volumes:
      - .:/home/wwwroot/sf4
    environment:
      - maildev_host=sf4_maildev
    depends_on:
      - maildev
      - mysql

  phpmyadmin:
    image: phpmyadmin/phpmyadmin
    container_name: sf4_phpmyadmin
    environment:
      PMA_HOST: sf4_mysql
      PMA_PORT: 3306
    ports:
      - 8080:80
    links:
      - mysql

  maildev:
    image: djfarrelly/maildev
    container_name: sf4_maildev
    ports:
      - 8001:80

现在我的问题是,我无法设法连接到MySQL。来自PHP或PhpMyAdmin的Wheter。我尝试了以下连接字符串,但是它们都不起作用:

DATABASE_URL=mysql://root:root@mysql:3306/sf4
DATABASE_URL=mysql://sf4:sf4@mysql:3306/sf4
DATABASE_URL=mysql://root:root@sf4_mysql:3306/sf4
DATABASE_URL=mysql://sf4:sf4@sf4_mysql:3306/sf4
... and hundreds more

但是我总是得到:

PDO::__construct(): php_network_getaddresses: getaddrinfo failed: Name or service not known

SQLSTATE[HY000] [2002] No route to host

SQLSTATE[HY000] [2002] Connection refused 

1 个答案:

答案 0 :(得分:0)

感谢@emix和@LinPy,他们在评论中帮助了我,这是固定的配置:

version: '3'
services:
  apache:
    build: .docker/apache
    container_name: sf4_apache
    ports:
      - 80:80
      - 443:443
    volumes:
      - .docker/config/vhosts:/etc/apache2/sites-enabled
      - .:/home/wwwroot/sf4:cached
    depends_on:
      - php

  mysql:
    image: mysql:5.7
    container_name: sf4_mysql
    #command: "--default-authentication-plugin=mysql_native_password"
    #restart: always
    ports:
      - 3306:3306
    volumes:
      - .docker/data/db:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: root
      MYSQL_DATABASE: sf4
      MYSQL_USER: sf4
      MYSQL_PASSWORD: sf4

  php:
    build: .docker/php
    container_name: sf4_php
    volumes:
      - .:/home/wwwroot/sf4
    environment:
      - maildev_host=sf4_maildev
    depends_on:
      - maildev
      - mysql

  phpmyadmin:
    image: phpmyadmin/phpmyadmin
    container_name: sf4_phpmyadmin
    environment:
      PMA_HOST: mysql
      PMA_PORT: 3306
    ports:
      - 8080:80
    links:
      - mysql

  maildev:
    image: djfarrelly/maildev
    container_name: sf4_maildev
    ports:
      - 8001:80

连接字符串:

DATABASE_URL=mysql://sf4:sf4@mysql/sf4