访问阿里云mysql出现Access denied for user ‘root‘@‘xxxxx‘ (using password: YES)

2023-11-18

问题:
在我连接远程阿里云的mysql时候,出现了Access denied for user 'root'@'xxxxx' (using password: YES)问题。

排查:
1、密码是否正确

2、阿里云的虚拟机是否开放了3306端口号。

我的就是密码正确,而且开放了3306端口的还是这样的错误,最后发现是权限不够的原因。

修改方法:

MySQL8不能将创建用户和授权放在一句话执行,所以要分开执行,然后再执行生效语句。

远程连接自己的虚拟机,然后使用 mysql -uroot -p 命令登录自己的mysql后执行下边三条命令。

1、创建账户名为root,host为%的用户。(host是ip,%是全部ip,可以把%换成一个ip,这样只能这个ip登录这个用户)

create user 'root'@'%' identified by '数据库密码';

2、赋予权限,with grant option这个选项表示该用户可以将自己拥有的权限授权给别人。

grant all privileges on *.* to 'root'@'%' with grant option;

3、改密码&授权超用户,flush privileges 命令本质上的作用是将当前user和privilige表中的用户信息/权限设置从mysql库(MySQL数据库的内置库)中提取到内存里。
MySQL用户数据和权限有修改后,这个命令可以在"不重启MySQL服务"的情况下直接生效。

flush privileges;

辅助命令

看当前用户:select user();

查看所有用户: select user,host from mysql.user;

删除用户:drop user '用户名'@'对应的host';

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

访问阿里云mysql出现Access denied for user ‘root‘@‘xxxxx‘ (using password: YES) 的相关文章

随机推荐