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)

你可能感兴趣的:(MySQL)