如何解决Mysql 拒绝连接到 Docker 上的 Adminer
我知道这是 this 的副本,但由于从未有人回答过,所以我重新发布了这个问题。
我正在尝试建立 php-apache 和 mysql 容器的基本连接。
docker-compose.yml
version: '3.1'
services:
php:
build:
context: .
dockerfile: Dockerfile
ports:
- 80:80
volumes:
- ./src:/var/www/html
db:
image: mysql
command: --default-authentication-plugin=mysql_native_password
restart: always
# Exposing the ports doesn't help either
# ports:
# - 3306:3306
environment:
MYSQL_ROOT_PASSWORD: example
adminer:
image: adminer
restart: always
ports:
- 8080:8080
Dockerfile
FROM php:7.2-apache
RUN docker-php-ext-install mysqli
我运行了一个简单的 docker-compose up
命令,并在 localhost:8080
上访问了 Adminer。
但是,尽管使用默认登录详细信息,即
server: db
username: root
password: example
我收到错误 SQLSTATE[HY000] [2002] Connection refused
。
我认为问题可能是我本地机器上的一些配置问题,因为我也无法使用其他人制作的基于 docker 的 LAMP 堆栈。
非常感谢任何帮助,
谢谢!
解决方法
事实证明耐心就是答案。
如果我等待的时间足够长(大约 4.5 分钟),mysql 容器会显示一个小的日志细节。
db_1 | 2021-03-09T08:21:03.882088Z 0 [System] [MY-010931] [Server] /usr/sbin/mysqld: ready for connections. Version: '8.0.23' socket: '/var/run/mysqld/mysqld.sock' port: 3306 MySQL Community Server - GPL.
然后登录就可以了。
注意:记录了类似的行,但这是关于端口 0,这是 3306。在失败后立即尝试失败。
必须等待3306端口的线路。
如果你们中的任何人可以就如何使我的 mysql 容器更快地初始化,给我反馈或建议,
我将不胜感激。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。