MySQL Access denied for user ‘root‘@‘localhost‘ (using password: YES/NO) 的原因以及解决方案

Access denied for user 'root'@'localhost' (using password: YES/NO) 的原因以及解决方案

这个错误我想应该是比较常见的一种错误了,但,出现错误并不可怕,可怕的是你并不知道原因,从而不知道如何解决问题。

Access denied for user 'root'@'localhost' (using password: YES/NO),还是先翻译一下比较好,意思为无权限使用root账号本地登录MySQL,括号内是:使用密码:是/不是。

首先,应该了解MySQL可以无密码登录的,通常是使用密码的,因此,在执行登录命令:mysql -uroot -p 的时候,报错提示会记录你是否使用了密码,进而出现错误。

其次,MySQL的登录分为远程登录和本地登录,localhost表示本地,通常的,安装完MySQL,root用户时默认的拥有权限本地登录的,但远程登录权限是关闭的,这么做的目的是保护MySQL的安全(如果有人恶意的远程登录你的MySQL是不是很恐怖??)。

那么,假设在一个正常的已安装完的MySQL,你如果随便输入密码,它就会报这个错了,原因就是密码错误,校验未通过

解决方案根据MySQL的版本分两种,mysql5.6.5之前的版本算低版本,之后的版本为高版本(MySQL密码的记录方式改变了,导致更改密码的方式改变了)。

mysql5.6.5版本之前的更新重置密码操作:

1,停止MySQL服务,

停止的方式很多,按安装方式来说,yum 安装方式:systemctl stop mysql #systemd管理方式

二进制以及编译安装方式:service mysqld stop# chkconfig的管理方式,是centos6的方式,目前centos7还是兼容的

2,MySQL安全模式带忽略密码校验参数启动

mysqld_safe --skip-grant-tables --skip-networking& #后台运行模式,否则需要新开窗口,那就会多很多事了 ,对吧

3,无密码方式登录MySQL,SQL语句更新root密码,从而重置密码。(密码校验功能已关闭了)

update user set Password=PASSWORD('你要重置的新密码') where user='root';

flush privileges;#刷新权限表

4,正常模式启动MySQL,输入重置的密码,验证密码的正确性。

systemctl restart mysql#重启服务   或者    service mysqld restart#重启服务

mysql -uroot -p你的新密码  #-p后没有空格,直接接密码。正常进入MySQL表示密码更新完成。

 

mysql5.6.5版本之后的更新重置密码操作:

1,2,4步都和上面的一样,第三步需要改变一下:

update mysql.user set authentication_string=PASSWORD('你的新密码') where USER='root';

flush privileges;#刷新权限表

总结:

MySQL和mariadb版本比较多,高版本密码的设定需要改变,先停止MySQL服务,在进入安全模式是必须的,尽量不要修改my.cnf文件(很多别的文章就是修改my.cnf,这是不建议的行为,因为如果忘记修改回来会出大问题的。),权限表的刷新也别忘了,其实MySQL内的那个privilege表你也刷不坏,放心刷就行了 。

你可能感兴趣的:(LNMP,mysql,java,数据库,centos,linux)