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
您可能感兴趣的文章:
- MySQL ERROR 1045 (28000): Access denied for user ''root''@''localhost'' (using password: NO) 的原因分解决办法
- IPv6设置后如何解决MySQL无法连接localhost的问题
- mysql ERROR 1044 (42000): Access denied for user ''''@''localhost'' to database
- mysql Access denied for user ‘root’@’localhost’ (using password: YES)解决方法
- mysql_connect localhost和127.0.0.1的区别(网络层阐述)
- PHP中使用localhost连接Mysql不成功的解决方法
- Mac os 解决无法使用localhost连接mysql问题
- Can''t connect to MySQL server on ''localhost'' (10048)问题解决方法
- mysql error 1130 hy000:Host''localhost''解决方案
- php运行提示Can''t connect to MySQL server on ''localhost''的解决方法
- Can''t connect to MySQL server on localhost (10061)解决方法
- linux mysql忘记密码的多种解决或Access denied for user ''root''@''localhost''
- MySQL 可以用localhost 连接,但不能用IP连接的问题解决方法
- php mysql localhost,127.0.0.1和ip区别
- php mysql localhost,127.0.0.1和ip区别
- mysql localhost,127.0.0.1 和ip区别
- mysql localhost与127.0.0.1以及ip连接的区别
- php连接mysql服务器时localhost与127.0.0.1的区别
- mysql localhost与127.0.0.1以及ip连接的区别
- mysql localhost与127.0.0.1以及ip连接的区别
- localhost,127.0.0.1和ip区别
- MySql 只能localhost 和 127.0.0.1访问 不能通过其他IP访问
- MySQL 127.0.0.1和localhost本质区别
- apache php localhost,127.0.0.1可以访问,ip不可以访问
- localhost与127.0.0.1及本机ip的区别
- localhost、127.0.0.1和本机IP区别
- localhost 127.0.0.1和本机ip三者的区别
- MySQL主机127.0.0.1与localhost区别总结
- Localhost 与127.0.0.1和IP的区别是什么
- localhost,127.0.0.1和本机ip三者的区别
- Localhost 与127.0.0.1和IP的区别?
- 连接MYSQL时,主机名为 localhost 和 127.0.0.1 的区别
- 连接MYSQL时,主机名为 localhost 和 127.0.0.1 的区别