网络编程入门如此简单 (四):一文搞懂 localhost 和 127.0.0.1
本文由萤火架构分享,原题“localhost 和 127.0.0.1 的区别是什么?”,原文链接“juejin.cn/post/7321049446443417638”,下文进行了排版和内容优化。
1、引言
继《你真的了解 127.0.0.1 和 0.0.0.0 的区别?》、《深入操作系统,彻底搞懂 127.0.0.1 本机网络通信》之后,这是整理收录的第 3 篇有关本机网络的网络编程基础文章。以下是正文内容。
今天在网上逛的时候看到一个问题,没想到大家讨论的很热烈,就是标题中这个:
前端同学本地调试的时候,应该没少和 localhost 打交道吧,只需要执行 npm run 就能在浏览器中打开你的页面窗口,地址栏显示的就是这个 http://localhost:xxx/index.html。
可能大家只是用,也没有去想过这个问题。联想到我之前合作过的一些开发同学对它们俩的区别也没什么概念,所以我觉得有必要普及下。
2、系列文章
本文是该系列文章中的第 4 篇:
《网络编程入门如此简单(一):假如你来设计网络,会怎么做?》
《网络编程入门如此简单(二):假如你来设计 TCP 协议,会怎么做?》
《网络编程入门如此简单(三):什么是 IPv6?漫画式图文,一篇即懂!》
《网络编程入门如此简单(四):一文搞懂 localhost 和 127.0.0.1》(* 本文)
3、localhost 是什么呢?
localhost 是一个域名,和大家上网使用的域名没有什么本质区别,就是方便记忆。
只是这个 localhost 的有效范围只有本机,看名字也能知道:local 就是本地的意思。
张三和李四都可以在各自的机器上使用 localhost,但获取到的也是各自的页面内容,不会相互打架。
4、从域名到程序
要想真正的认清楚 localhost,我们还得从用户是如何通过域名访问到程序说起。
以访问百度为例。
1)当我们在浏览器输入 baidu.com 之后,浏览器首先去 DNS 中查询 baidu.com 的 IP 地址。
为什么需要 IP 地址呢?打个比方,有个人要寄快递到你的公司,快递单上会填写:公司的通讯地址、公司名称、收件人等信息,实际运输时快递会根据通信地址进行层层转发,最终送到收件人的手中。网络通讯也是类似的,其中域名就像公司名称,IP 地址就像通信地址,在网络的世界中只有通过 IP 地址才能找到对应的程序。(请详读《什么是公网 IP 和内网 IP?NAT 转换又是什么鬼?》)
DNS 就像一个公司黄页,其中记录着每个域名对应的 IP 地址,当然也有一些域名可能没做登记,就找不到对应的 IP 地址,还有一些域名可能会对应多个 IP 地址,DNS 会按照规则自动返回一个。我们购买了域名之后,一般域名服务商会提供一个域名解析的功能,就是把域名和对应的 IP 地址登记到 DNS 中。(请详读《理论联系实际,全方位深入理解 DNS》)
这里的 IP 地址从哪里获取呢?每台上网的电脑都会有 1 个 IP 地址,但是个人电脑的 IP 地址一般是不行的,个人电脑的 IP 地址只适合内网定位,就像你公司内部的第几栋第几层,公司内部人明白,但是直接发给别人,别人是找不到你的。
如果你要对外部提供服务,比如百度这种,你就得有公网的 IP 地址,这个 IP 地址一般由网络服务运营商提供,比如你们公司使用联通上网,那就可以让联通给你分配一个公网 IP 地址,绑定到你们公司的网关服务器上,网关服务器就像电话总机,公司内部的所有网络通信都要通过它,然后再在网关上设置转发规则,将网络请求转发到提供网络服务的机器上。
2)有了 IP 地址之后,浏览器就会向这个 IP 地址发起请求,通过操作系统打包成 IP 请求包,然后发送到网络上。
网络传输有一套完整的路由协议,它会根据你提供的 IP 地址,经过路由器的层层转发,最终抵达绑定该 IP 的计算机。
3)计算机上可能部署了多个网络应用程序,这个请求应该发给哪个程序呢?
这里有一个端口的概念,每个网络应用程序启动的时候可以绑定一个或多个端口,不同的网络应用程序绑定的端口不能重复,再次绑定时会提示端口被占用。
通过在请求中指定端口,就可以将消息发送到正确的网络处理程序。但是我们访问百度的时候没有输入端口啊?这是因为默认不输入就使用 80 和 443 端口,http 使用 80,https 使用 443。我们在启动网络程序的时候一定要绑定一个端口的,当然有些框架会自动选择一个计算机上未使用的端口。
5、localhost 和 127.0.0.1 的区别是什么?
有了前面的知识储备,我们就可以很轻松的搞懂这个问题了。
localhost 是域名,上文已经说过了。
127.0.0.1 呢?是 IP 地址,当前机器的本地 IP 地址,且只能在本机使用,你的计算机不联网也可以用这个 IP 地址,就是为了方便开发测试网络程序的。
我们调试时启动的程序就是绑定到这个 IP 地址的。
这里简单说下,我们经常看到的 IP 地址一般都是类似 X.X.X.X 的格式,用"."分成四段。其实它是一个 32 位的二进制数,分成四段后,每一段是 8 位,然后每一段再转换为 10 进制的数进行显示。
那 localhost 是怎么解析到 127.0.0.1 的呢?经过 DNS 了吗?没有。每台计算机都可以使用 localhost 和 127.0.0.1,这没办法让 DNS 来做解析。
那就让每台计算机自己解决了。每台计算机上都有一个 host 文件,其中写死了一些 DNS 解析规则,就包括 localhost 到 127.0.0.1 的解析规则,这是一个约定俗成的规则。
如果你不想用 localhost,那也可以,随便起个名字,比如 wodehost,也解析到 127.0.0.1 就行了。
甚至你想使用 baidu.com 也完全可以,只是只能自己自嗨,对别人完全没有影响。
PS:以下两篇可以深入进行阅读:
你真的了解 127.0.0.1 和 0.0.0.0 的区别?
深入操作系统,彻底搞懂 127.0.0.1 本机网络通信
6、域名的等级划分
localhost 不太像我们平常使用的域名,比如 www.juejin.cn 、baidu.com、csdn.net, 这里边的 www、cn、com、net 都是什么意思?localhost 为什么不需要?
域名其实是分等级的,按照等级可以划分为顶级域名、二级域名和三级域名...
1)顶级域名(TLD):
顶级域名是域名系统中最高级别的域名。它位于域名的最右边,通常由几个字母组成。顶级域名分为两种类型:通用顶级域名和国家顶级域名。常见的通用顶级域名包括表示工商企业的.com、表示网络提供商的.net、表示非盈利组织的.org 等,而国家顶级域名则代表特定的国家或地区,如.cn 代表中国、.uk 代表英国等。
2)二级域名(SLD):
二级域名是在顶级域名之下的一级域名。它是由注册人自行选择和注册的,可以是个性化的、易于记忆的名称。例如,juejin.cn 就是二级域名。我们平常能够申请到的也是这种。目前来说申请 xxx.com、xxx.net、xxx.cn 等等域名,其实大家不太关心其顶级域名 com\net\cn 代表的含义,看着简短好记是主要诉求。
3)三级域名(3LD):
三级域名是在二级域名之下的一级域名。它通常用于指向特定的服务器或子网。例如,在 blog.example.com 中,blog 就是三级域名。www 是最常见的三级域名,用于代表网站的主页或主站点,不过这只是某种流行习惯,目前很多网站都推荐直接使用二级域名访问了。
域名级别还可以进一步细分,大家可以看看企业微信开放平台这个域名:developer.work.weixin.qq.com,com 代表商业,qq 代表腾讯,weixin 代表微信,work 代表企业微信,developer 代表开发者。这种逐层递进的方式有利于域名的分配管理。
按照上边的等级定义,我们可以说 localhost 是一个顶级域名,只不过它是保留的顶级域,其唯一目的是用于访问当前计算机。
7、多网站共用一个 IP 和端口
上边我们说不同的网络程序不能使用相同的端口,其实是有办法突破的。
以前个人博客比较火的时候,大家都喜欢买个虚拟主机,然后部署个开源的博客程序,抒发一下自己的感情。为了挣钱,虚拟主机的服务商会在一台计算机上分配 N 多个虚拟主机,大家使用各自的域名和默认的 80 端口进行访问,也都相安无事。这是怎么做到的呢?
如果你有使用 Nginx、Apache 或者 IIS 等 Web 服务器的相关经验,你可能会接触到主机头这个概念。主机头其实就是一个域名,通过设置主机头,我们的程序就可以共用 1 个网络端口。
首先在 Nginx 等 Web 程序中部署网站时,我们会进行一些配置,此时在主机头中写入网站要使用的域名。
然后 Nginx 等 Web 服务器启动的时候,会把 80 端口占为己有。
然后当某个网站的请求到达 Nginx 的 80 端口时,它会根据请求中携带的域名找到配置了对应主机头的网络程序。
然后再转发到这个网络程序,如果网络程序还没有启动,Nginx 会把它拉起来。
8、私有 IP 地址
除了 127.0.0.1,其实还有很多私有 IP 地址,比如常见的 192.168.x.x。
这些私有 IP 地址大部分都是为了在局域网内使用而预留的,因为给每台计算机都分配一个独立的 IP 不太够用,所以只要局域网内不冲突,大家就可劲的用吧。你公司可以用 192.168.1.1,我公司也可以用 192.168.1.1。
但是如果你要访问我,就得通过公网 IP 进行转发。
大家常用的 IPv4 私有 IP 地址段分为三类:
1)A 类:从 10.0.0.0 至 10.255.255.255;
2)B 类:从 172.16.0.0 至 172.31.255.255;
3)C 类:从 192.168.0.0 至 192.168.255.255。
这些私有 IP 地址仅供局域网内部使用,不能在公网上使用。
除了上述三个私有的 IPv4 地址段外,还有一些保留的 IPv4 地址段:
1)用于本地回环测试的 127.0.0.0 至 127.255.255.255 地址段,其中就包括题目中的 127.0.0.1,如果你喜欢也可以给自己分配一个 127.0.0.2 的 IP 地址,效果和 127.0.0.1 一样。
2)用于局域网内部的 169.254.0.0 至 169.254.255.255 地址段,这个很少接触到,如果你的电脑连局域网都上不去,可能会看到这个 IP 地址,它是临时分配的一个局域网地址。
这些地址段也都不能在公网上使用。
近年来,还有一个现象,就是你家里或者公司里上网时,光猫或者路由器对外的 IPv4 地址也不是公网 IP 了,这时候获得的可能是一个类似 100.64.x.x 的地址,这是因为随着宽带的普及,运营商手里的公网 IP 也不够了,所以运营商又加了一层局域网,而 100.64.0.0 这个网段是专门分给运营商做局域网用的。
如果你使用阿里云等公有云,一些云产品的 IP 地址也可能是这个,这是为了将客户的私有网段和公有云厂商的私有网段进行有效的区分。
其实还有一些不常见的专用 IPv4 地址段,完整的 IP 地址段定义可以看这里:www.iana.org/assignments…
9、IPv6
你可能也听说过 IPv6,因为 IPv4 可分配的地址太少了,不够用,使用 IPv6 甚至可以为地球上的每一粒沙子分配一个 IP。只是喊了很多年,大家还是喜欢用 IPv4,这里边原因很多,这里就不多谈了。
IPv6 地址类似于:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX。
它是 128 位的,用":"分成 8 段,每个 X 是一个 16 进制数(取值范围:0-F),IPv6 地址空间相对于 IPv4 地址有了极大的扩充。比如:2001:0db8:3c4d:0015:0000:0000:1a2f:1a2b 就是一个有效的 IPv6 地址。(请详读《什么是 IPv6?漫画式图文,一篇即懂!》)(本文已同步发布于:http://www.52im.net/thread-4702-1-1.html)
10、参考资料
[1] 你真的了解 127.0.0.1 和 0.0.0.0 的区别?
[2] 深入操作系统,彻底搞懂 127.0.0.1 本机网络通信
[3] 什么是 IPv6?漫画式图文,一篇即懂!
[4] 一文读懂什么是 IPv6
[5] IPv6 技术详解:基本概念、应用现状、技术实践(上篇)
[6] 什么是公网 IP 和内网 IP?NAT 转换又是什么鬼?
[7] 深入操作系统,一文搞懂 Socket 到底是什么
[8] 面视必备,史上最通俗计算机网络分层详解
[9] 通俗讲解,有了 IP 地址,为何还要用 MAC 地址?
[10] 理论联系实际,全方位深入理解 DNS
评论