MySQL拒绝与主机%的用户建立连接

时间:2012-12-16 13:33:35

标签: mysql privileges

我已经定义了MySQL 5:

CREATE DATABASE foo DEFAULT CHARACTER SET = 'utf8';
GRANT ALL ON foo.* TO foo@'%' IDENTIFIED BY 'foo';
FLUSH PRIVILEGES;

但是,当用户foo访问时,传递foo,拒绝连接。 当我将其更改为

GRANT ALL ON foo.* TO foo@localhost IDENTIFIED BY 'foo';

MySQL让我进来。 为什么第一个不起作用? AFAIK,%应匹配任何内容。

更新:发现此信息,可能与http://forums.mysql.com/read.php?30,158830,158830

有关

手动参考:(在那里找不到答案)

1 个答案:

答案 0 :(得分:3)

来自mysql documentation

  

一个非常常见的错误是插入一个包含Host ='%'和User ='some_user'的新条目,认为这使您可以指定localhost从同一台计算机进行连接。这不起作用的原因是默认权限包括Host ='localhost'和User =''的条目。因为该条目具有比'%'更具体的主机值'localhost',所以当从localhost连接时,它优先于新条目使用!正确的过程是插入第二个条目,其中Host ='localhost'和User ='some_user',或删除具有Host ='localhost'和User =''的条目。删除条目后,请记住发出FLUSH PRIVILEGES语句以重新加载授权表。另请参见第6.2.4节“访问控制,第1阶段:连接验证”。

执行第一个命令后检查mysql.user

CREATE DATABASE foo DEFAULT CHARACTER SET = 'utf8';
GRANT ALL ON foo.* TO foo@'%' IDENTIFIED BY 'foo';
FLUSH PRIVILEGES;
select * from mysql.user where User='foo';