zoukankan      html  css  js  c++  java
  • Mysql重置root密码遇到的坑(忘记密码)

    1、原理

    通过配置参数“skip_grant_tables”在mysql启动时跳过grant_tables(授权表),从而通过命令来充值root帐号的密码

    2、方式

    首先需要停止mysql服务

    (1)在my.ini文件的[mysqld]块下增加“skip_grant_tables”,然后重启mysql服务,再以管理员权限打开cmd执行一些列命令重置密码

    步骤如下:

    A、找到my.ini文件(右击mysql服务找到可执行文件路径,从所在的目录或其它层级目录搜索),在[mysqld]块下增加“skip_grant_tables”

    B、重启mysql服务

    C、以管理员权限打开cmd命令窗口,执行mysql -uroot –p直接回车不用输入密码

    D、选择数据库:use mysql

    E、更新root的密码:update user set authentication_string=password('新密码') where user='root' and Host='localhost'

    F、刷新权限:flush privileges

    G、退出:quit

    H、重新登录:mysql -uroot -p提示输入密码,这时输入密码才能登录

    I、回到 my.ini 配置文件移除“skip_grant_tables”,再重启mysql

    (2)直接通过命令指定参数“skip_grant_tables”启动mysql,再执行命令修改密码(与1的步骤除了指定跳过授权表参数的方式不同以外,其它都一样)

    A、在第一个cmd窗口执行 mysqld --defaults-file="C:ProgramDataMySQLMySQL Server 5.7my.ini" --skip-grant-tables   ---注意路径(以你的实际情况为准)

    其它步骤同上

    参考:

    Windows下MySQL5.7 root 密码重置

    https://blog.csdn.net/hey_yf/article/details/80024706

    Windows下Mysql5.7忘记root密码的解决方法

    https://www.cnblogs.com/yuwentims/p/9172463.html

    3、遇到的坑

    同过修改my.ini的方式配置“skip_grant_tables”再保存千万要注意编码的格式“ANSI”

    (1)用Notepad++将修改了my.ini的配置

    (2)重启mysql服务,就启动不了(超时),通过命令去执行接下来的操作会报“ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO)”的错误

    (3)第一想到的是去百度,无果后从系统事件日志开始着手,发现了一些莫名其它的错误(其实部分是系统里其它程序的错误日志):

    A、首先根据关键字看到的是“服务 MySQL57 意外停止。这发生了 7 次。”并没卵用

    B、然后就在这个错误的隔壁找其它错误 “应用程序-特定 权限设置并未向在应用程序容器 不可用 SID (不可用)中运行的地址 LocalHost (使用 LRPC) 中的用户 NT AUTHORITYLOCAL SERVICE SID (S-1-5-19)授予针对 CLSID ”像这种不明不白的错误头脑一发热并没有多想,然后就是百度解决并没有屁用

    解决方式:

    https://www.cnblogs.com/ibgo/p/3550674.html

    http://www.ntxz.net/?p=580

    解决了这个日志,但是对mysql并没影响,现在才明白找错了方向

    (4)于是将所有的事件日志清除,重启computer

    (5)终于发现了一条这样的错误 “mysql 启动报错--发现系统错误2,系统找不到指定的文件”

    解决方式:

    https://blog.csdn.net/Marvel__Dead/article/details/63262641?locationNum=4&fps=1

    解决了报错,mysql服务可以启动了

    接着执行重置的命令,终于报了一条有意义的错“Found option without preceding group in config file:XXX; Fatal error in defaults handling.“,找到了原来是my.ini编码惹得祸!

    改成ANSI,一切就顺利了…

    参考:

    MySQL报错: Found option without preceding group in config file:XXX; Fatal error in defaults handling.

    https://blog.csdn.net/life_android/article/details/56512606

    4、注意

    (1)确保服务里只有一个MySql

  • 相关阅读:
    Java 9 揭秘(14. HTTP/2 Client API)
    Java 9 揭秘(13. Collection API 更新)
    Java 9 揭秘(12. Process API 更新)
    JAVA数组与List相互转换
    linux下开启oracle服务和开启监听
    Centos7安装Redis
    Hibernate乐观锁无法Catch到org.hibernate.StaleObjectStateException
    Eclipse远程调试Tomcat
    Centos7 使用Docker搭建Oracle测试环境
    Maven安装Oracle驱动包到本地仓库
  • 原文地址:https://www.cnblogs.com/hepc/p/9499527.html
Copyright © 2011-2022 走看看