【发布时间】:2020-04-17 14:11:36
【问题描述】:
我有 2 个用于 php 应用程序和 mysql 的 docker 容器。两者都可以完美地单独工作。我可以在localhost:8000 访问我的php 应用程序,并且可以使用MySQL Workbench 在localhost:3306 连接mysql。
但是,我在容器内的 php 应用程序无法连接到另一个容器内的 mysql db。
我的 docker-compose.yml 文件如下:
version: '3'
services:
website:
container_name: php-app
image: php-app
build:
context: ./
volumes:
- php-app:/var/www/html/
ports:
- 8000:80
depends_on:
- mysql
mysql:
image: mysql:8.0
container_name: mysql-server-80
command: --default-authentication-plugin=mysql_native_password
volumes:
- .:/application
restart: always
environment:
- MYSQL_ROOT_PASSWORD=123456
- MYSQL_DATABASE=testdb
- MYSQL_USER=root
- MYSQL_PASSWORD=123456
ports:
- "3306:3306"
volumes:
jayde-ci:
mysql:
我在基于 codeigniter 的 php 应用程序中的数据库配置文件如下:
$db['default'] = array(
'dsn' => '',
'hostname' => 'mysql',
'username' => 'root',
'password' => '123456',
'database' => 'test',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);
【问题讨论】:
-
您是否也尝试过在配置中使用 localhost -
'hostname' => 'localhost',? -
@NigelRen 我也试过 localhost
-
假设
php-app是一个普通的命名卷,您的volumes: ['php-app:/var/www/html/']声明将阻止容器查看镜像源代码的更新。如果有一次您在此文件中包含不正确的信息,它会一直停留在那里,直到您明确删除该卷。
标签: php mysql docker docker-compose containers