mysql docker не может подключиться извне контейнера - PullRequest
0 голосов
/ 17 апреля 2020

Я создал docker -компонентный файл для PHP dev, но я не могу подключиться к БД с помощью sequel pro, ни из приложения.

version: '3'
services:

  #PHP Service
  app:
    build:
      context: .
      dockerfile: Dockerfile
    image: digitalocean.com/php
    container_name: app
    restart: unless-stopped
    tty: true
    environment:
      SERVICE_NAME: app
      SERVICE_TAGS: dev
    working_dir: /var/www
    volumes:
      - ./:/var/www
      - ./php/local.ini:/usr/local/etc/php/conf.d/local.ini
    networks:
      - app-network

  #Nginx Service
  webserver:
    image: nginx:alpine
    container_name: webserver
    restart: unless-stopped
    tty: true
    volumes:
      - ./:/var/www
      - ./nginx/conf.d/:/etc/nginx/conf.d/
    ports:
      - "80:80"
      - "443:443"
    networks:
      - app-network

  #MySQL Service
  db:
    image: mysql:latest
    container_name: db
    restart: unless-stopped
    tty: true
    ports:
      - "3306:3306"
    expose:
      # Opens port 3306 on the container
      - '3306'
    environment:
      MYSQL_DATABASE: laravel
      MYSQL_USER: laraveluser
      MYSQL_PASSWORD: root
      MYSQL_ROOT_PASSWORD: root
      SERVICE_TAGS: dev
      SERVICE_NAME: mysql
    volumes:
      - ./mysql/data:/var/lib/mysql
      - ./mysql/my.cnf:/etc/my.cnf
    networks:
      - app-network

#Docker Networks
networks:
  app-network:
    driver: bridge

все работает нормально и ошибок нет отображается, но когда я пытаюсь каким-либо образом подключиться к БД, она не работает docker-compose exec app PHP artisan migrate, ни с сиквелом Pro, что не так с моей конфигурацией?

Единственный способ получить доступ к БД с помощью docker-compose exec db bash

здесь полный репо

Ответы [ 2 ]

0 голосов
/ 18 апреля 2020

прямо из репозитория GitHub У меня есть ответ, хотя я еще не пробовал, так как думаю, что сейчас я буду придерживаться 5.7.

Возможно, вам придется добавить --default-auth=mysql_native_password к вашему команда

Mysql: 8 по умолчанию использует caching_sha2_password https://dev.mysql.com/doc/refman/8.0/en/upgrading-from-previous-series.html#upgrade -caching-sha2-password

# 454 (комментарий)

0 голосов
/ 17 апреля 2020

После анализа вашего кода я обнаружил, что вам нужно обновить .env.example file

Заменить DB_HOST=db в строке 10.

Вы должны иметь пропустил его, но он уже упоминался в сообщении , о котором вы говорили, под заголовком «Шаг 8 - Изменение параметров среды и запуск контейнеров» .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...