docker-compose 中的 MySQL -- 访问被拒绝
Posted
技术标签:
【中文标题】docker-compose 中的 MySQL -- 访问被拒绝【英文标题】:MySQL in docker-compose -- access denied 【发布时间】:2017-11-19 07:42:40 【问题描述】:我尝试使用docker-compose
启动mysql
服务器。这是docker-compose.yaml
部分:
mysql:
restart: always
image: mysql:latest
ports:
- "3306:3306"
volumes:
- /Users/user/Documents/.docker/mysql/config:/etc/mysql/
- /Users/user/Documents/.docker/mysql/data:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD='123'
- MYSQL_ROOT_HOST='172.18.0.1'
你看我已经指定了root密码和主机,就像here所说的那样。然后我尝试连接到 db(如果重要,使用 Intellij Idea):
jdbc:mysql://localhost:3306/?user=root&password=123&ssl=false
但它不接受凭据并写入日志:
Access denied for user 'root'@'172.18.0.1' (using password: YES)
请告知如何修复它。谢谢。
【问题讨论】:
授予您的用户从本地主机连接的权限。 你的意思是root用户不能从localhost连接吗? 是的,root 用户目前只有连接@172.18.0.1
的权限,据我所知,不能从本地主机连接
我不需要从本地主机连接的能力,因为我所有的应用程序都将在主机上运行。在任何情况下,mysql 都需要从 localhost 访问吗?
你的连接字符串是jdbc:mysql://localhost:3306/?user=root&password=123&ssl=false
见localhost
?这是个问题。
【参考方案1】:
当这些不同时,您很可能已经初始化了 mysql 数据目录:
environment:
- MYSQL_ROOT_PASSWORD='123'
- MYSQL_ROOT_HOST='172.18.0.1'
MySQL 映像仅在创建 /var/lib/mysql 目录时支持这些变量。
因此,如果您不关心数据,请清空您的卷:/Users/user/Documents/.docker/mysql/data
,或从 mysql 终端手动更改凭据。
【讨论】:
谢谢你,你是对的,那些不是初始设置。清除持久性目录有帮助。 我尝试从mysql终端更改密码,但仍然需要清除持久性目录,否则环境变量没有设置root主机 如果您确实关心数据,您会怎么做?为什么会这样设计?如果要更改用于创建容器的 MYSQL 用户名该怎么办?以上是关于docker-compose 中的 MySQL -- 访问被拒绝的主要内容,如果未能解决你的问题,请参考以下文章
无法将docker Spring-Boot应用程序与docker-compose中的mysql容器和flyway连接起来