php mysql localhost,127.0.0.1和ip区别
一家之言:
localhost与127.0.0.1的区别
localhost与127.0.0.1的区别是什么?相信有人会说是本地ip,曾有人说,用127.0.0.1比localhost好,可以减少一次解析。看来这个入门问题还有人不清楚,其实这两者是有区别的。
no1:
localhost也叫local ,正确的解释是:本地服务器
127.0.0.1在windows等系统的正确解释是:本机地址(本机服务器)
no2:
localhot(local)是不经网卡传输!这点很重要,它不受网络防火墙和网卡相关的的限制。
127.0.0.1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。
一般设置程序时本地服务用localhost是最好的,localhost不会解析成ip,也不会占用网卡、网络资源。
有时候用localhost可以,但用127.0.0.1就不可以的情况就是在于此。猜想localhost访问时,系统带的本机当前用户的权限去访问,而用ip的时候,等于本机是通过网络再去访问本机,可能涉及到网络用户的权限。
他家之言:
1. mysql -h 127.0.0.1 的时候,使用tcp/ip连接,
mysql server 认为该连接来自于127.0.0.1或者是"localhost.localdomain"
2. mysql -h localhost 的时候,是不使用tcp/ip连接的,而使用unix socket;
此时,mysql server则认为该client是来自"localhost"
3. mysql权限管理中的"localhost"有特定含义:
—— mysql手册 5.6.4 ..... a host value may be a hostname or an ip number, or 'localhost' to indicate the local host.
注意:虽然两者连接方式有区别,但当localhost 为默认的127.0.0.1时,两种连接方式使用的权限记录都是以下的1.row的记录(因为记录在前,先被匹配)
*************************** 1. row ***************************
host: localhost
user: root
......
*************************** 2. row ***************************
host: 127.0.0.1
user: root
证明:
shell> mysql -h 127.0.0.1
mysql> status;
current user: root@127.0.0.1
ssl: not in use
current pager: stdout
using outfile: ''
using delimiter: ;
server version: 5.1.33-log source distribution
protocol version: 10
connection: 127.0.0.1 via tcp/ip
shell> mysql -h locahost
mysql> status;
current user: root@localhost
ssl: not in use
current pager: stdout
using outfile: ''
using delimiter: ;
server version: 5.1.33-log source distribution
protocol version: 10
connection: localhost via unix socket
shell> mysql -h xxxx(ip)
mysql> status;
current user: root@ip
ssl: not in use
current pager: stdout
using outfile: ''
using delimiter: ;
server version: 5.1.33-log source distribution
protocol version: 10
connection: xxxx(ip) via tcp/ip
推荐阅读
-
php mysql localhost,127.0.0.1和ip区别
-
MySQL刚安装完只认得的主机是:localhost和127.0.0.1
-
php中关于mysqli和mysql区别的一些知识点分析
-
PHP实现一个ip(如:127.0.0.1)和多个域名(虚拟主机)的绑定,127.0.0.1虚拟主机
-
mysql_connect localhost和127.0.0.1的区别(网络层阐述),_PHP教程
-
pdo-[求助]关于PHP 链接 Mysql 底层 对于IP 和 Hostname 的处理方式?
-
PHP函数addslashes和mysql_real_escape_string的区别_PHP教程
-
关于php中使用IP和localhost连接问题
-
php 链接 mysql 数据库无法使用 localhost ,只能用 127.0.0.1
-
PHP函数addslashes和mysql_real_escape_string的区别_PHP教程