我正在尝试为 Nginx + PHP(Laravel) + MySQL 构建 docker compose 容器,但我不断收到连接被拒绝错误
docker-compose.yml
version: "3"
services:
nginx:
image: nginx:latest
ports:
- '8080:80'
volumes:
- ./nginx:/etc/nginx/conf.d
- ./logs/nginx:/var/logs/nginx
- ./apps:/var/www/html
depends_on:
- php
restart: always
php:
image: laradock/php-fpm:2.2-7.2
volumes:
- ./apps:/var/www/html
restart: always
mysql:
image: mariadb
ports:
- '33060:3306'
volumes:
- ./db:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=root
restart: always
In ./apps
我有一个全新的 Laravel 应用程序,具有基本的 SQL 设置
所有容器都运行没有错误,我可以使用连接到 MySQL 容器
mysql -u 127.0.0.1 -P 33060 -u root -p
但是当我尝试从浏览器访问或直接 ssh 进入 php 容器时,我不断收到错误 2002。
我的服务器上运行着 nginx 和 mysql,所以我使用 8080 和 33060 端口,不确定这是否是问题所在。
.env
DB_CONNECTION=mysql
DB_HOST=127.0.0
DB_PORT=3306
DB_DATABASE=homestead
DB_USERNAME=root
DB_PASSWORD=secret
谢谢你的帮助。
从中获得想法这个 Github 问题 https://github.com/docker-library/php/issues/320
我的第一个猜测是它正在试图找到 mysql unix
套接字文件,当需要通过非本地主机连接时
联系。如果您使用撰写文件来启动它们,那么您
可以连接到docker提供的dns名称(即链接:
docker-mysql,将dns名称设置为docker-mysql)。所以你必须
更改您的连接线:
- php -r "new PDO('mysql:host=localhost;port=3306;charset=utf8', 'root', '123123');"
+ php -r "new PDO('mysql:host=docker-mysql;port=3306;charset=utf8', 'root', '123123');"
通过改变解决了这个问题DB_HOST
到 docker 容器名称.env
file
DB_HOST=docker_mysql_1
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)