与127.0.0.1和IP的区别是什么(Localhost)

大家好,今天小悦来为大家解答以上问题。Localhost,与127.0.0.1和IP的区别是什么很多人还不知道,现在让我们一起来看看吧!

一般设置程序时本地服务用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

本文到此结束,希望对大家有所帮助。

所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请联系 931519643@qq.com

联系我们

联系我们