Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 716|回复: 0

Ubuntu下连接mysql出现 ERROR 1698 (28000): Access denied for user 'root'@'localhost'错误解决方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-7-19 17:14:13 | 显示全部楼层 |阅读模式

    ubuntu版本:18.04    mysql版本:5.7.24  

     

     

    ubuntu安装mysql后用root账户登入会出现问题:ERROR 1698 (28000): Access denied for user 'root'@'localhost'

     

    可能是因为初始密码为空;按空格回车后还是报一样的错

     

    这样就只能使用debian-sys-maint账户修改root账户密码了。

    debian-sys-maint账户是安装mysql时系统自动生成的mysql用户,debian和ubuntu系统都会这样做, 

    停止或重启服务都靠它,删除它就无法重启或者雷霆之服务。
    如果你修改了它的密码或覆盖掉密码,也会出现错误:
    error: 'Access denied for user 'debian-sys-maint'@'localhost' (using password: YES)'

     

     1  查看debian-sys-maint账户密码:

     

    debian-sys-maint账户是安装mysql时系统自动生成的,密码随机生成。

     

    终端输入: sudo vim /etc/mysql/debian.cnf  


     

    password就是密码,如果是复制密码由后面使用,切忌不要将密码字符串后面的空格也复制进去,否者后面粘贴密码登入账户时会出现错误。

     

    2 用刚才查看的密码登入debian-sys-maint账户:

     

    终端输入指令:mysql -u debian-sys-maint -p ,然后输入刚才查看的debian-sys-maint账户密码。 注意-u可以和debian-sysy连在一起,-p不能。u表示用户名,p表示密码。

     

    3 进入mysql后重新设置root账号密码:

     

    sql指令:

    use mysql   (一定要写上这条语句,很多网上的解决方案缺少这条语句,导致后一条语句出现no database selected错误,这是因为有选择新创建的表所在的数据库)

    UPDATE user SET authentication_string=PASSWORD('你的密码') where USER='root';

    5.7之前的版本用:

    update user set password=PASSWORD("你的密码") where User = 'root';

    指令的大小写都行,注意语句后面分号。

     

     

    退出mysql(sql指令:quit)并重启mysql(终端指令:sudo service mysql restart)

    这时候用root账户和修改后的密码登入时(终端指令:mysql -uroot -p)会发现还是报错!这时候其实密码是修改成功的,但是plugin root 的字段是auth_socket,需要修改过来。

     

    4 修改plugin root

     

    查看plugin root

    用debian-sys-maint账户和密码登入mysql,然后输入sql语句:

    use mysql

    select user,plugin from  user;

     

     

    修改plugin root

    update user set authentication_string =password('你的密码'),plugin='msyql_native_password' where user='root';

     

     

    然后推出并重启mysql,再用root账户登入就可以了。

     

     

     总结:

    1 这篇文章是遇到这个问题后查找网上资料整合而成的,网上关于这个问题的资料很多但是也有很多不足:比如指令不够详细,尤其是很多资料缺少使用mysql时需要use mysql这个指令的提示,这对小白用户不太友好。再一个,大部分相关文章缺少修改plugin root的部分,所以我折腾了很多遍修改密码但还是不成功。

    2 很多时候问题的原因只是一个很小的错误,比如少一个分号,空格,复制密码吧后面的换行符也复制进去了等,所以,尽量减少操作失误。

    3 遇到问题多分析反馈的错误原因

    4 网上的资料很多,但终究是别人的,不一定能解决自己的问题(但可以提供解决问题思路),遇到问题多查找相关资料,找解决办法,这个过程可能很花费时间很烦人,但是也能拓展不少知识,最后总结理解就能成为自己的东西。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-22 22:33 , Processed in 0.058829 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表