Подключите контейнер laravel к существующему контейнеру mysql через docker compose - PullRequest
0 голосов
/ 05 ноября 2019

Я новичок в Docker, я пытаюсь подключить существующий контейнер MySQL к моему приложению Laravel через docker-compose.

Где файл MySQL docker-compose.yml похож на

version: '3'

services:
  web:
    container_name: ${APP_NAME}_web
    build:
     context: ./docker/web
    ports:
      - "9000:80"
    volumes:
      - ./:/var/www/app
    depends_on:
      - db
  db:
    container_name: ${APP_NAME}_db
    image: mysql:5.7
    ports:
      - "3307:3306"
    restart: always
    volumes: 
      - dbdata:/var/lib/mysql/
    environment:
      - MYSQL_ROOT_PASSWORD=root
      - MYSQL_DATABASE=laravel_docker_db
volumes:
  dbdata:
    driver: local
    driver_opts:
       type: none
       device: /storage/docker/laravel_mysql_data
       o: bind

Этот скрипт загружает последнюю версию mysql и создает новый контейнер. Я просто хочу соединить контейнер MYSQL с моим приложением

, где мой существующий контейнер MYSQL создается с определенным IP-адресом с использованием сети моста и работает на док-машине.

enter image description here

Мне интересно, могу ли я определить существующие конфигурации контейнеров MYSQL в контексте db ?

Ответы [ 2 ]

2 голосов
/ 05 ноября 2019

Попробуйте этот файл docker-compose:

version: '3.5'
services:
  db:
    container_name: myapp_db
    image: mysql:5.7
    ports:
      - "3307:3306"
    restart: always
    volumes:
      - dbdata:/var/lib/mysql/
    environment:
      - MYSQL_ROOT_PASSWORD=root
      - MYSQL_DATABASE=laravel_docker_db
    networks:
      - myapp-network

networks:
  myapp-network:
    driver: bridge

Ситуация имеет два случая: 1. Если ваш экземпляр laravel тоже находится в Docker - просто добавьте в файл .env следующие строки:

DB_HOST=myapp_db
DB_PORT=3306
DB_DATABASE=laravel_docker_db
DB_USERNAME=root
DB_PASSWORD=root

2.Если вы не используете докер для laravel - просто измените переменную DB_HOST=localhost

1 голос
/ 05 ноября 2019

В файле .env:

DB_HOST=db
DB_PORT=3306
DB_DATABASE=your database name
DB_USERNAME=root
DB_PASSWORD=root
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...