28
$ 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

怎么会这样?主要问题 -如何授予所有主机上所有数据库的所有权限?

升级版:

$ 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

4 回答 4

14

正如您在此处看到的,如果在没有主机名或主机名的情况下使用 UNIX mysqld,则使用套接字localhost

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

于 2013-10-31T16:57:22.813 回答
12

我知道这个踏板很旧,但是很可能没有正确回答。

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

跳过名称解析 = 1

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

于 2017-09-05T01:40:09.923 回答
11

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

SHOW GRANTS

你可能会看到类似的东西

GRANT ALL ... 'root'@'127.0.0.1'

我刚刚确认了我的本地安装,似乎 MySQL 不会自动解析主机名。您可以为localhost127.0.0.1 添加另一个授权或仅使用

于 2013-10-31T16:55:29.183 回答
0

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

几个脚本函数,比如mysqli_connect()在 php 中可能localhost用于连接 MySQL:你不能(不应该)在每个脚本中替换localhostwith 。127.0.0.1

尝试通过将bind-address=localhost,socket=/var/mysql/mysql.sock等添加socket=/tmp/mysql.sock到 my.cnf 文件来解决此问题,但这不起作用。

要解决这个问题(在 MacOS 上),请注意文件中的mysql.default_socket设置/etc/php.ini指向/var/mysql/mysql.sock,而 MySQL 的 default_socket 是/tmp/mysql.sock.

所以,要么编辑你的php.ini文件,要么创建一个指向 MySQL 的 default_socket 的软链接:

mkdir /var/mysql
ln -s /tmp/mysql.sock /var/mysql/mysql.sock

PS - MySQL 将 127.0.0.1 视为 TCP 连接,将 localhost 视为 unix 套接字连接:详情请点击此处

于 2018-10-10T09:30:08.040 回答