MySQL密码重置思路mysql
MySQL的密码是存放在user表里面的,修改密码其实就是修改表中记录。sql
重置的思路是是想办法不用密码进入系统,而后用数据库命令修改表user中的密码记录。数据库
查了下,MySQL5系统在网上建议的方法是以--skip-grant-tables参数启动mysql服务,该参数指示在启动时不加载受权表,所以启动成功后root用户能够空密码登录安全
mysqld –skip-grant-tables
登录以后能够用服务器
UPDATE user SET authentication_string='' WHERE user='root';
这类命令设置密码或者将密码置空。多线程
可是,实测mysqld –skip-grant-tables这样的命令行,在mysql8中没法成功启动,并且测试了该参数放在ini文件里面也一样没法启动架构
MySQL8系统密码重置的两个思路并发
两条思路,或者用--init-file参数在服务启动时加载并运行修改密码的命令文件,该命令一旦执行,服务启动后密码即已经清除或者重置,启动服务后便可以空密码或指定密码登入。分布式
或者继续研究–skip-grant-tables命令行参数下服务不能启动的缘由,解决问题,而后启动服务后以空密码登入,手工输入命令,执行清除或者重置mysql.user表中的密码记录字段。微服务
推荐使用前者。
具体操做流程以下:
方法一:利用--init-file参数解决
该参数指定服务启动时先执行一个包含sql命令文件,所以,只须要将重置密码的命令写在该文件中,以此参数指定启动时执行该命令,启动完成便可重置系统密码了。加q群:834962734 可获取一份Java架构进阶学习资源(高并发+Spring源码+JVM原理解析+分布式架构+微服务架构+多线程并发原理等...这些成为架构师必备的内容)以及Java进阶学习路线图。
第一步,关掉系统服务
net stop mysql
第二步,建立一个文本文件,内含一条密码修改命令
ALTER USER 'root'@'localhost' IDENTIFIED BY '';
第三步:命令行方式启动服务器,指定启动时执行上述的密码修改命令文件
mysqld --init-file=d:mysqlc.txt --console
具体操做截图
方法二,想办法让--skip-grant-tables参数用起来
同方法一,先关掉系统服务
实测,在mysql8系统下,用mysqld --console --skip-grant-tables --shared-memory能够无密码启动服务
服务启动后,以空密码登入系统
mysql.exe -u root
而后执行sql命令将root用户密码设置为空
UPDATE mysql.user SET authentication_string='' WHERE user='root' and host='localhost';
具体操做截图
MySQL8的一些特性致使老方法重置不大管用了,建议使用--init-file参数解决,实测安全可靠。