繁体   English   中英

从 .env 或 dockerFile/docker-compose.yml 获取环境变量,到 config,php 以连接到 mysql 数据库

[英]Get env variables from .env or dockerFile/docker-compose.yml, to config,php to connect to mysql database

我想在 docker 中定义一个 env 变量,而不是硬编码 db_username 和密码。 我是 Docker 的新手,所以有些东西我仍然需要了解更多。

我想问的另一个问题是,如果其他人想要运行我的容器,比如从 github 克隆,他们将不得不为自己设置 env 变量以连接到数据库,对吗? 创建一个 .env 之类的东西..

配置文件

<?php

define('DB_SERVER', getenv('DB_SERVER'));
define('DB_USERNAME', getenv('DB_USERNAME'));
define('DB_PASSWORD', getenv('DB_PASSWORD')); 
define('DB_NAME', getenv('DB_NAME'));

$link = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);

if ($link === false) {
    die ("ERROR: Could not connect. " . mysqli_connect_error());
}

?>

.env

DB_SERVER=db
DB_USERNAME=dbuser
DB_PASSWORD=dbpassword
DB_NAME=company

docker-compose.yml

db:
  build: ./backend
  restart: always
  ports:
    - "3306:3306"
  volumes:
    - /var/lib/mysql
  environment:
    - MYSQL_ROOT_PASSWORD=dbpassword
php:
  build: ./frontend
  ports:
    - "80:80"
  volumes: 
    - ./frontend:/var/www/html
  environment:
    - DB_SERVER=${DB_SERVER}
    - DB_USERNAME=${DB_USERNAME}
    - DB_PASSWORD=${DB_PASSWORD}
    - DB_NAME=${DB_NAME}
  env_file: ./.env
  links:
    - db

./frontend 中的 Dockerfile

FROM php:7.2-apache

RUN docker-php-ext-install mysqli

WORKDIR /var/www/html

COPY . /var/www/html/

./backend 中的 Dockerfile

FROM mysql:5.7

COPY ./demo.sql /docker-entrypoint-initdb.d

我不知道现在的方式是否从 env 文件中获取变量,当我使用 docker-compose up 运行并转到 192.168.99.100 时,我的应用程序正在运行,但是我得到了

在 .yml 文件中,我认为我不需要设置环境变量,但我正在测试是否可以获取该变量,直接放入 config.php,对于将运行我的容器的人来说,只需要运行“ docker-compose up”,而不是设置所有内容。

警告:mysqli_connect():(HY000/1045):第 8 行 /var/www/html/config.php 中的用户 'dbuser'@'172.17.0.3'(使用密码:YES)访问被拒绝

我不知道如何解决这个问题。 所以基本上,这是两个问题,为什么会出现这个错误,以及我是否正确地设置了环境变量。

我设法让它工作,我真的不知道我改变了什么,但基本上我删除了environment:php容器,并移动到db容器,使用来自 dockerhub 的 mysql 图像环境变量。

我已经解决了这个问题你需要添加变量 PHP_FPM_CLEAR_ENV=no

 environment: - PHP_FPM_CLEAR_ENV=no

之后一切正常!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM