首页 > 数据库 > mysql教程 > 为什么设置MYSQL_ROOT_PASSWORD后仍无法访问MySQL?

为什么设置MYSQL_ROOT_PASSWORD后仍无法访问MySQL?

DDD
发布: 2024-12-01 16:00:14
原创
274 人浏览过

Why Can't I Access MySQL Even After Setting MYSQL_ROOT_PASSWORD?

如果设置了 MYSQL_ROOT_PASSWORD 如何访问 MySQL

问题:

尽管设置了 MYSQL_ROOT_PASSWORD 环境变量,仍尝试访问MySQL 导致错误:用户 root@localhost 的访问被拒绝(使用密码:是)。

解决方案:

针对包含 MySQL 数据库文件系统的预先存在的卷启动 MySQL 容器时会出现此问题。在这种情况下,容器会跳过初始化,环境变量不起作用。

解决方案:

  1. 删除现有数据卷:

    docker-compose down -v
    登录后复制
  2. 重新创建容器:

    docker-compose up -d
    登录后复制

注意: 删除卷将删除任何现有的数据库数据。如有必要,请创建备份。

其他信息:

  • 官方 MySQL Docker 映像文档指出:“如果您启动,以下变量都不会产生任何影响数据目录已包含数据库的容器。”
  • 其他官方数据库 Docker 镜像也可能会出现同样的问题(例如, Postgres、MongoDB)。
  • 如果转换为绑定挂载,则需要手动删除其所有内容以强制初始化。

以上是为什么设置MYSQL_ROOT_PASSWORD后仍无法访问MySQL?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板