ERROR 1045 (28000): Access denied for user

同事咨询一个关于MySQL用户权限的问题,相同的用户密码在远程机器可以访问成功。但相同的用户密码在本机通过IP访问确报错。

ERROR 1045 (28000): Access denied for user。

首先想到的是该用户的IP有访问限制。检查发现本机IP在授权的范围内。

MariaDB [(none)]> select user,host from mysql.user where user='mgc';
+------+-------------+
| user | host        |
+------+-------------+
| mgc  | 192.168.0.% |
+------+-------------+
1 row in set (0.00 sec)

远程机器通过IP可以正常访问数据库。

$ mysql -umgc -p123 -h192.168.0.100-P3336 -e"select @@server_id"  
mysql: [Warning] Using a password on the command line interface can be insecure.
+-------------+
| @@server_id |
+-------------+
|          43 |
+-------------+

本机通过IP访问数据库报ERROR 1045 (28000)的错误。

$ mysql -umgc -p123 -h192.168.0.100 -P3336 -e"select @@server_id"
ERROR 1045 (28000): Access denied for user 'mgc'@'test43' (using password: YES)

仔细查看报错信息,ERROR 1045 (28000): Access denied for user ‘mgc’@’test43’ (using password: YES)

发现有些疑问?为什么用mgc@’192.168.0.100’ 用户访问,
却报Access denied for user ‘mgc’@’test43’ 用户无法访问呢。
检查一下mysql.user表中host为’test43’的用户。

MariaDB [(none)]> select user,host from mysql.user where host='test43';
+------+-------+
| user | host  |
+------+-------+
|      | test43|
| root | test43|
+------+-------+

发现mysql.user表中有个host为’test43’的匿名用户。删除这个匿名用户后,原脚本运行正常。

MariaDB [(none)]> drop user ''@'test43;
Query OK, 0 rows affected (0.01 sec)

MariaDB [(none)]> flush privileges;
Query OK, 0 rows affected (0.00 sec)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值