Mysql localhost!= 127.0.0.1?

时间:2013-10-31 16:50:19

标签: mysql

$ mysql -u root -h 127.0.0.1 -e 'show tables' created_from_host;
+-----------------------------+
| Tables_in_created_from_host |
+-----------------------------+
| test                        |
+-----------------------------+

$ mysql -u root -h localhost -e 'show tables' created_from_host;
ERROR 1049 (42000): Unknown database 'created_from_host'

$ cat /etc/hosts
127.0.0.1       localhost.localdomain localhost
127.0.0.1       localhost
::1     localhost6.localdomain6 localhost6

怎么可能?主要问题 - 如何为所有主机上的所有数据库授予root权限?

UPD:

$ mysql -u root -h 127.0.0.1 -pzenoss -e "show grants";
+----------------------------------------------------------------------------------------------------------------------------------------+
| Grants for root@localhost                                                                                                              |
+----------------------------------------------------------------------------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*3715D7F2B0C1D26D72357829DF94B81731174B8C' WITH GRANT OPTION |
| GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION                                                                           |
+----------------------------------------------------------------------------------------------------------------------------------------+
$ mysql -u root -h localhost -pzenoss -e "show grants";
+----------------------------------------------------------------------------------------------------------------------------------------+
| Grants for root@localhost                                                                                                              |
+----------------------------------------------------------------------------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*3715D7F2B0C1D26D72357829DF94B81731174B8C' WITH GRANT OPTION |
| GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION                                                                           |
+----------------------------------------------------------------------------------------------------------------------------------------+

UPD2:

zends> SHOW GLOBAL VARIABLES LIKE 'skip_networking';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| skip_networking | OFF   |
+-----------------+-------+
1 row in set (0.00 sec)

zends> SELECT user,host FROM mysql.user WHERE user='root'; 
+------+-----------------------+
| user | host                  |
+------+-----------------------+
| root | 127.0.0.1             |
| root | ::1                   |
| root | localhost             |
| root | localhost.localdomain |
+------+-----------------------+
4 rows in set (0.00 sec)

4 个答案:

答案 0 :(得分:13)

正如您所看到的here,如果在没有主机名或主机名localhost的情况下使用,UNIX mysqld将使用套接字。

所以它有所不同,在GRANT系统中,这种差异变得明显。

答案 1 :(得分:10)

我知道这个步骤已经过时了,但很可能没有得到正确回答。

默认情况下,mysql会对名称进行解析,因此127.0.0.1和localhost将解析相同的名称。但是,您可以在my.cnf中关闭名称解析:

skip-name-resolve = 1

然后localhost和127.0.0.1 NOT 将不再相同。因此,您要么保留名称解析,要么限制自己仅在您的授权中使用localhost或仅限于127.0.0.1 但是:如果您执行后者,则必须使用这些凭据访问我们的数据库。

答案 2 :(得分:8)

通过127.0.0.1登录并执行以下语句:

SHOW GRANTS

您可能会看到类似

的内容
GRANT ALL ... 'root'@'127.0.0.1'

我刚刚在本地安装时确认,似乎MySQL不会自动解析主机名。您可以为localhost添加其他授权,也可以只使用127.0.0.1

答案 3 :(得分:0)

这导致在MacOS上设置本地开发环境时出现问题。

几个脚本函数,例如php中的mysqli_connect()可能正在使用localhost连接到MySQL:您不能(不必)将localhost替换为{{ 1}}。

试图通过在my.cnf文件中添加127.0.0.1bind-address=localhostsocket=/var/mysql/mysql.sock等来解决此问题,但这没用。

要解决此问题(在MacOS上),请注意,socket=/tmp/mysql.sock文件中的mysql.default_socket设置指向/etc/php.ini,而MySQL的default_socket是{{1 }}。

因此,要么编辑您的/var/mysql/mysql.sock文件,要么创建到MySQL的default_socket的软链接:

/tmp/mysql.sock

PS-127.0.0.1被MySQL视为TCP连接,而localhost被视为unix套接字连接:详细信息here