linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)

linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)

###安装mysql时忘记为root用户设置密码,导致root用户本地登陆时拒绝访问!

ERROR 1698(28000): Access denied for user ‘root’@‘localhost’

查看/etc/mysql/debian.cnf
会在debian.cnf文件中看到用户名user和密码password,这是安装数据库的时候自动生成的用户,可以用于登陆数据库,密码会表较长,但是不要尝试修改这个密码

linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)_第1张图片
使用得到的用户名和密码登陆数据库
linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)_第2张图片
查看root权限等信息
在这里插入图片描述linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)_第3张图片
我这是更改过的正常的,你的authentication_string后面应该是空的,因为没有设置密码,plugin后面是auth_socket,只要将其改为caching_sha2_password,并设置密码就可以了

alter user 'root'@'localhost' identified with caching_sha2_password by '123456';

这样密码就修改好了,密码为123456,可以查看一下
linux关于mysql的root用户登陆时拒绝本地访问ERROR 1698 (28000)_第4张图片
退出数据库使用root正常登陆就可以了

如果安装5.7版本或者5.7以后的8.0版本并且没有为root用户设置密码,密码将为空,并且它将使用auth_socket插件,只要利用debian-sys-maint用户登陆数据库,将auth_socket更改为caching_sha2_password就可以了

你可能感兴趣的:(linux,mysql,linux,mysql)