localhost与127.0.0.1的区别是什么

问题描述

今天我在访问mysql时,遇到127.0.0.1不能够访问,而localhost可以访问的问题。

解决方案

1.之前有人说用127.0.0.1本地ip,它比localhost好,可以减少一次解析,我也就相信了。
今天重新看搜索了下,看了还是我不清楚,其实这两者是有区别的。

2.localhost也叫local ,正确的解释是:本地服务器
127.0.0.1在windows等系统的正确解释是:本机地址(本机服务器)

3.localhot(local)是不经网卡传输!这点很重要,它不受网络防火墙和网卡相关的的限制。
127.0.0.1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制。

4.一般设置程序时本地服务用localhost是最好的,localhost不会解析成ip,也不会占用网卡、网络资源。

5.有时候用 localhost 可以,但用 127.0.0.1 就不可以的情况就是在于此。猜想 localhost访问时,系统带的本机当前用户的权限去访问,而用IP的时候,等于本机是通过网络再去访问本机,可能涉及到网络用户的权限。

MySQL 连接时主机类型

a.mysql -h 127.0.0.1 的时候,使用 TCP/IP 连接
b.mysql -h localhost 的时候,是不使用 TCP/IP 连接的,而使用 Unix socket;此时,mysql server 则认为该 client 是来自 “localhost”
MySQL 手册 5.6.4 ….. A Host value may be a hostname or an IP number, or ‘localhost’ to indicate the local host.
简而言之:主要区别是 localhost 是通过 unix domain socket 方式来连接,而 127.0.0.1 则是走的 TCP 协议方式连接

分别用上述方式访问主机,然后使用status命令
前者:Connection: 127.0.0.1 via TCP/IP
后者:Connection: Localhost via UNIX socket

转载于:https://blog.51cto.com/10884109/2141335

  • 0
    点赞
  • 0
    收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值