127.0.0.1 和 localhost 有什么区别?

在日常开发中,我们经常把 127.0.0.1 和 localhost 当成同义词:都表示"访问本机"。大多数时候确实没问题,但一旦遇到访问失败、连接被拒绝、服务明明启动了却打不开等情况,它俩的差异就会立刻变得关键。

这篇文章用开发者视角,了解两者的概念、差异、常见坑和解决方案

一、先给结论:它们不是一回事

  • 127.0.0.1:一个IP 地址(IPv4 回环地址)
  • localhost:一个主机名(hostname),需要先解析成 IP 才能使用

它俩"经常等价",是因为 localhost 通常会被解析到回环地址(如 127.0.0.1 或 ::1)。

二、127.0.0.1:明确的 IPv4 回环地址

1)它属于回环网段

127.0.0.1 属于 127.0.0.0/8 这一整段回环网段(loopback network)。这一网段专门用于本机到本机的通信。

特点:

  • 请求不会发到物理网卡,不会走外网
  • 常用于本地开发、服务自测、进程间通信等

2)IPv6 对应的是 ::1

如果在 IPv6 环境下访问本机回环地址,对应的是:

  • ::1(IPv6 loopback)

三、localhost:一个名字,最终连到谁取决于"解析结果"

localhost 是一个主机名,使用前必须先被解析成 IP(类似域名解析)。

通常系统会在 hosts 文件里写死它的映射,例如:

  • 127.0.0.1 localhost
  • ::1 localhost(很多系统也会配置)
    所以关键点是:
    localhost 最终是 IPv4 还是 IPv6,完全取决于你的系统解析策略/hosts 配置。

四、最常见的坑:localhost 解析到 IPv6(::1)

很多"诡异"问题的根源其实是这一条:

  • localhost → 可能解析成 ::1(IPv6)
  • 127.0.0.1 → 永远是 IPv4

典型现象

  • 服务启动了,访问 127.0.0.1:8080 正常
  • 访问 localhost:8080 却失败(连接被拒绝/超时)

根本原因

服务可能只监听 IPv4(比如只绑定了 127.0.0.1),但 localhost 被系统优先解析到了 ::1(IPv6),于是访问走了 IPv6,当然连不上。

反过来也可能:

  • 只监听 IPv6(::1 或 ::)
  • 用 127.0.0.1 访问失败

六、遇到"localhost 不通,127.0.0.1 通

1、先确认 localhost 解析到了什么

Windows(PowerShell)

powershell 复制代码
Windows(PowerShell)

看输出是:

  • ::1 → 说明走 IPv6
  • 127.0.0.1 → 说明走 IPv4

再看一下 hosts 实际映射:

powershell 复制代码
type C:\Windows\System32\drivers\etc\hosts

最快修复:改 hosts,让 localhost 指向 127.0.0.1(立即见效)

1.以管理员权限打开记事本

开始菜单搜索 "记事本" → 右键 以管理员身份运行

2.打开 hosts 文件

C:\Windows\System32\drivers\etc\hosts

(文件类型记得选 "所有文件 .")

3.确保有这行(没有就加上):

bash 复制代码
127.0.0.1    localhost

4.如果有这行,先注释掉(很多情况下就是它导致 localhost 走 IPv6):

bash 复制代码
# ::1    localhost

5.保存后刷新 DNS(管理员 PowerShell):

powershell 复制代码
ping localhost

6.再测

powershell 复制代码
ping localhost

应该变成解析到 127.0.0.1,这时 localhost:端口 一般就恢复了。

相关推荐
兆子龙40 分钟前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构
SuperEugene1 小时前
表单最佳实践:从 v-model 到自定义表单组件(含校验)
前端·javascript·vue.js
昨晚我输给了一辆AE861 小时前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码11 小时前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码11 小时前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
Dilettante2581 小时前
我的 Monorepo 实践经验:从基础概念到最佳实践
前端·前端工程化
只会cv的前端攻城狮1 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
Java小卷2 小时前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader2 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端
兆子龙3 小时前
从 float 到 Flex/Grid:CSS 左右布局简史与「刁钻」布局怎么搞
前端·架构