连接laravel与docker上的mysql容器

问题描述 投票:2回答:2

在Docker上我已经有了一个Laravel容器和Container MySQL,如何在Docker上连接MySQL容器和容器Laravel?

enter image description here

mysql laravel docker
2个回答
0
投票

这就是docker-compose的用途!

看看这个教程:https://docs.docker.com/compose/wordpress/

它试图做类似的事情:将wordpress连接到mysql。关键是docker-compose.yml中定义的docker容器共享同一个网络 - 您可以使用它们的逻辑名称来引用每个容器。了解WORDPRESS_DB_HOST环境变量如何设置为db:3306 - 将解析为docker网络中mysql容器的IP。


0
投票

基本上,所有容器必须在同一网络中运行。

# create your network
$ docker network create laravel

# start your container and link it to your network
$ docker run -d --network="laravel" --name="mysql01" mysql:8.0

# after your mysql is up and running, connect your second and third container like this
$ docker run -d --network="laravel" --name="latihananakit_web" yourimage:yourtag
$ docker run -d --network="laravel" --name="latihananakit_app" yourimage:yourtag

我建议在这种情况下使用docker-compose,因为它使整个docker run事情变得容易多了。

见这里参考: https://docs.docker.com/compose/ https://github.com/bitnami/bitnami-docker-laravel/blob/master/docker-compose.yml

TL; DR: 像这样创建你的docker-compose.yml(你可以根据需要更改环境变量或其他配置):

version: '2'

services:
  mariadb:
    image: 'bitnami/mariadb:latest'
    environment:
      - ALLOW_EMPTY_PASSWORD=yes
      - MARIADB_USER=my_user
      - MARIADB_DATABASE=my_database
      - MARIADB_PASSWORD=my_password

  myapp:
    tty: true
    image: bitnami/laravel:5-debian-9
    environment:
      - DB_HOST=mariadb
      - DB_USERNAME=my_user
      - DB_DATABASE=my_database
      - DB_PASSWORD=my_password
    depends_on:
      - mariadb
    ports:
      - 3000:3000
    volumes:
      - ./:/app

并通过在同一目录中执行docker-compose up -d来获得所有功能。

© www.soinside.com 2019 - 2024. All rights reserved.