Docker Compose phpmyadmin не подключается к MySQL - PullRequest
0 голосов
/ 10 апреля 2019

У меня есть файл docker compose, который в основном пытается создать среду в стиле WAMP / LAMP.

По сути, PHPMyAdmin не может подключиться к MySQL. Просматривая ответы здесь, выяснилось, что это проблема устаревшей аутентификации с использованием MySQL Image 8, поэтому я добавил:

  command: --default-authentication-plugin=mysql_native_password

но это не сработало, поэтому я опустился до mysql image5.7 и проблема все еще присутствует. По какой-то причине я не могу подключиться к MySQL и получаю сообщение об ошибке:

mysqli_real_connect(): php_network_getaddresses: getaddrinfo failed: Try again

и

mysqli_real_connect(): (HY000/2002): php_network_getaddresses: getaddrinfo failed: Try again

Вот копия моего Docker Compose, который, я думаю, не делает ничего странного.

Надеясь, что кто-то может уточнить это для меня.

version: "3.1"
services:

    site: 
      build: .
      ports :
        - "80:80"
      volumes:
        - ./www:/var/www/html/
      links:
        - database
      networks:
        - php-network

#######################################
# PHP MY ADMIN
#######################################
    phpmyadmin:
      build:
        context: .
        dockerfile: PHPMYADMIN.Dockerfile
      restart: always
      links:
        - database:mysql
      environment:
        PMA_HOST: mysql
        PMA_PORT: 3306
      ports:
        - "8080:80"
      environment:
        - MYSQL_USERNAME=admin
        - MYSQL_PASSWORD=root
      networks:
        - php-network

#######################################
# MySQL server
#######################################
    database:
      image: mysql:5.7.25
      ports:
        - "3306:3306"
      container_name: db-mysql 
      restart: always 
      environment:
        - MYSQL_ROOT_PASSWORD=root
        - MYSQL_DATABASE=test_db
        - MYSQL_USER=admin
        - MYSQL_PASSWORD=root
      networks:
        - php-network

networks:
  php-network:
    driver: bridge

Я также видел упоминание флага «зависит от», который тоже пробовал, но он также не позволил мне подключиться. У меня была одна и та же ошибка.

Ответы [ 3 ]

0 голосов
/ 10 апреля 2019

Речь идет о названии контейнера.

database:
     image: mysql:5.7.25
     ports:
       - "3306:3306"
       - **container_name: db-mysql**

and in your phpcontainer:

 phpmyadmin:
      build:
        context: .
        dockerfile: PHPMYADMIN.Dockerfile
      restart: always
      links:
        - database:mysql
      environment:
        **PMA_HOST: mysql**
        PMA_PORT: 3306

you define host as mysql, which in docker network will be unrecognizable.
try switching PMA_HOST to db-mysql.

Извините за плохое форматирование.

Также используйте docker ps, чтобы увидеть имена контейнеров докеров и выяснить, какие хосты вам нужно подключить.

0 голосов
/ 11 апреля 2019

У меня теперь работает это со следующим:

version: "3.1"
services:
    www:
        build: .
        ports: 
            - "8081:80"
        volumes:
            - ./www:/var/www/html/
        links:
            - db
        networks:
            - default

#######################################
# MySQL server
#######################################
    db:
        image: mysql:5.7.25
        ports: 
            - "3306:3306"
        environment:
            MYSQL_DATABASE: test_db
            MYSQL_ROOT_PASSWORD: test
        volumes:
            - ./dump:/docker-entrypoint-initdb.d
            - persistent:/var/lib/mysql
        networks:
            - default

#######################################
# PHP MY ADMIN
#######################################
    phpmyadmin:
        image: phpmyadmin/phpmyadmin
        links: 
            - db:db
        ports:
            - 8080:80
        environment:
            MYSQL_USER: user
            MYSQL_PASSWORD: test
            MYSQL_ROOT_PASSWORD: test
volumes:
    persistent:
0 голосов
/ 10 апреля 2019

В соответствии с настройкой службы phpmyadmin вы пытаетесь связаться с контейнером mysql по mysql адресу:

environment:
  PMA_HOST: mysql
  PMA_PORT: 3306

Но контейнер с сервером mysql доступен по адресам database или db-mysql.

Итак, вам нужно изменить phpmyadmin конфигурацию сервиса на:

environment:
  PMA_HOST: database
  PMA_PORT: 3306
...