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

问题:
在我连接远程阿里云的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';

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值