经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
MySQL8.0 on Windows下重置root密码的BUG
来源:cnblogs  作者:Leohahah  时间:2019/3/5 8:54:51  对本文有异议

很多人都知道MySQL忘记root密码之后可以通过skip-grant-tables来暂时免密登录MySQL,从而修改root密码,但是这种方式一方面有安全隐患,另一方面也并不怎么适用于Windows系统,今天在通过此方式修改MySQL8.0 on Windows的root密码时遇到了这个问题,写个小随笔记一下。

参考:

https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html

https://bugs.mysql.com/bug.php?id=90554

首先看下修改MySQL密码的两种方式:

方法一:

在MySQL的启动文件中添加skip-grant-tables参数后重启MySQL,然后免密登录MySQL后执行:

  1. ALTER user root@'localhost' identified by 'newpasswd';

然后重启MySQL即可。

方法二:

创建一个名为root_newpass.txt的文本文件,放入如下内容:

  1. ALTER user root@'localhost' identified by 'newpasswd';

然后使用此文件启动一次数据库:

  1. mysqld --defaults-file="C:\\ProgramData\\MySQL\\MySQL Server 8.0\\my.ini" --init-file=root_newpass.txt
  2. # --defaults-file必须写在--init-file之前

如果是在Linux下则无需添加--defaults-file项。

使用方法一无法在MySQL8.0 on Windows上修改root密码的问题在哪儿?

在官方文档关于--skip-grants-tables的描述中5.7和8.0版本里有一句明显的差异,8.0里多了如下一句:

  1. If the server is started with the --skip-grant-tables option to disable authentication checks,
  2. the server enables --skip-networking automatically to prevent remote connections.

其意思是当你使用--skip-grant-tables跳过授权检测启动MySQL时,MySQL会自动启用--skip-networking参数,这会阻止远程访问。

如果系统是windows那你需要开启shared-memory/shared-memory-base-name或者enable-named-pipe/socket这两对参数任意一对才能本地连接到mysql进行密码重置(关于这俩名字熟悉sqlserver的应该不陌生),但Windows版本的mysql并不会默认设置这些参数,这导致MySQL8.0在Windows上通过--skip-grant-tables重置密码是一件很麻烦的事,虽然这比5.7更安全。

推荐使用方法二在任意平台上进行root密码的重置。

原文链接:http://www.cnblogs.com/leohahah/p/10472142.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号