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=falselocalhost ?这是个问题。 【参考方案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连接起来

docker-compose:nodejs + mysql无法连接mysql

使用 docker-compose 运行 MySQL

docker-compose部署mysql配置

docker-compose部署mysql无法访问

Spring Boot + docker-compose + MySQL:连接被拒绝