• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL8.0.23版本的root密码重置最优解法

    该方法编辑于2021年2月7日,自己使用的版本是8.0.23,事情的起因要从袁隆平教授说起…要从一本教科书说起,有一章节是“MySQL安全管理与权限管理”,其中有提到更改root账户

    ps:此方法适用于任何忘记,胡乱修改或已经糟蹋root密码的同学

    本着实践主义的精神,我在自己的MySQL数据库中(当前登陆为root账户)中敲下了:

    update user set authentication_string=MD5("123") where user = "root" and host = "localhost";
    flush privileges;
    

    在这里不得不说一下现在的百度google教程,同学可以先自己看一下自己的user表结构,在user表中一般而言,我们最关注三个字段,分别是localhost的host列,用户名root的user列,以及保存密码的authentication_string列

    desc user;
    

    注意:保存密码的字段已经不是password了(旧版本可能是,而且很多改root密码教程也是还停留在password),其次我这个较新的版本已经在这里不适用password函数,教材使用的是MD5加密,目前仍然很多百度的都是下面这种,这个方法已经完全不适用了

    ...password = password("123")...
    

    当我敲下上面的代码之后,重新退出重启服务器并尝试使用新密码123登陆的时候,吧唧…密码错误报错

    ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

    之后就是连续三个小时的百度攻略,找回密码操作…接连的失败告终…
    24小时之后,误打误撞的删除了原authentication_string保存的密码,然后重新设置新的密码,下面上干货,亲测~

    1.免密登录

    将mysql登陆设置为免密登陆(这一步我暂时不知道可不可以使用debian.cnf配置中的debian-sys-maint账户登陆进行修改root的密码,我怕debian权限不够无法改动root所以还是选择了root免密登陆,有兴(wu)趣(liao)的同学可以尝试下,这一步主要是为了能进入服务器),具体方法为:
    进入配置文件,我的配置文件在

    /etc/mysql/mysql.conf.d
    

    使用sudo打开,因为必须要su权限才能更改etc的配置,当然因为我没有在家目录下自定义配置,所以都是默认的,这个配置很有可能每个人位置不一样,而且你们也是很可能自己配置了,那么可以用在终端上用mysql --help查看此时哪个配置在发挥作用,当然也不是一下子能找到的,比如我目前配置文件在第二个/etc/mysql/my.cnf中,但是打开来没有配置的选项,里面是两个路径,这个路径才是真正的配置文件,就好比是一个“嵌套”

    sudo vim mysqld.cnf
    

    打开之后在第15行左右的位置[mysqld]的下面插入一行


    之后保存退出vim即可

    2.清空authentication_string密码

    其实这一步是我误打误撞进去的,也是被网上各种复制的教程带跑偏了,今天晚上在研究user表时,看到plugin字段默认是caching_sha2_password,所以我想到有可能之前不应该用md5加密,而应该用sha2,所以:
    注意:这是关键步骤

    update user set authentication_string=sha2("1234",32) where user = 'root';
    flush privileges;
    

    然后再看user表中root的数据,发现authentication_string的值居然变为null了,此时我有预感我可能可以真正的免密登陆了
    回到配置文件(注意使用sudo),把上面的在配置中加的那一行代码

    skip-grant-tables
    

    给删了,然后重启MySQL服务器,然后登陆

    mysql -u root
    

    果然真的能登陆了,真正的免密登陆,因为此时root账户的密码已经被清掉了,但是为啥用sha2摘要算法不是算出一个密码而是清掉一个密码我就不懂了,肯定有大佬知道…

    3.重新设置密码

    重新设置密码就简单了,一行代码搞定:

    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123';
    

    ps:MySQL在第一次安装之后,也是没有密码的,第一次登陆服务器时可能需要sudo mysql -uroot登陆,登陆之后自己再设置mysql的root密码,设置方法和上述代码一模一样

    4.结束

    之后就可以用新密码重新登陆MySQL啦

    mysql -u root -p123

    5.最后

    到此这篇关于MySQL8.0.23版本的root密码重置最优解法 的文章就介绍到这了,更多相关MySQL8.0.23 root密码重置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • mysql 8.0.24版本安装配置方法图文教程
    • MySQL8.0.24版本Release Note的一些改进点
    • mysql的MVCC多版本并发控制的实现
    • 关于MyBatis连接MySql8.0版本的配置问题
    • 解决seata不能使用mysql8版本的问题方法
    • 详解DBeaver连接MySQL8以上版本以及解决可能遇到的问题
    • IDEA使用mybatis-generator及配上mysql8.0.3版本遇到的bug
    • MySQL5.x版本乱码问题解决方案
    • CentOS7版本安装Mysql8.0.20版本数据库的详细教程
    • Mysql5.7及以上版本 ONLY_FULL_GROUP_BY报错的解决方法
    • 解决mysql8.0.19 winx64版本的安装问题
    • django2.2 和 PyMySQL版本兼容问题
    • Linux下二进制方式安装mysql5.7版本和系统优化的步骤
    • mysql 8.0.18各版本安装及安装中出现的问题(精华总结)
    • 超详细教你怎么升级Mysql的版本
    上一篇:MySQL中查询json格式的字段实例详解
    下一篇:MySQL之MHA高可用配置及故障切换实现详细部署步骤
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL8.0.23版本的root密码重置最优解法 MySQL8.0.23,版本,的,root,密码,