你知道当咱们在浏览器中输入 URL 后到得到咱们须要的网页资源,这中间须要经历怎样的流程吗?客户端(浏览器)是如何找到目标服务器并从服务器得到所须要的资源的?数据库
若是你从未思考或了解过上述的问题,那么我相信本文会对你在平常的项目实践中有必定的帮助,在本文中我将尽量详细地介绍浏览器中输入 URL 回车后与服务器进行通讯的流程。浏览器
当咱们在浏览器中输入 URL 而且回车后,主要发生四个过程:查找 IP 、创建链接、相互通讯、断开链接。主要流程概述以下:缓存
在详细介绍各个流程前,让咱们先来了解一下接下来须要接触到的一些名词概念。服务器
IP 地址:指互联网协议地址。是 IP 协议提供的一种统一的地址格式,它为互联网上的每个网络和每一台主机分配一个逻辑地址,以此来屏蔽物理地址的差别。互联网上每个网络和每一台主机都会被分配的一个 IP 地址。咱们能够把 IP 地址当成具体到门牌号码的地址,只有经过 IP 地址才能肯定一台主机的位置。网络
域名:是由一串用点分隔的名字组成的 Internet上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。因为纯数字的 IP 地址难以被记忆,因此使用有表明意义的字符(域名)来代替纯数字的 IP 地址,但最终仍须要经过域名来查找其对应的 IP 地址才可以找到相应主机的位置。分布式
DNS :域名系统,是互联网的一项服务。它做为将域名和 IP 地址相互映射的一个分布式数据库,可以令人更方便地访问互联网。操作系统
URL :统一资源定位符,有时也被俗称为网页地址(网址)。指的是因特网上各类资源的地址。cdn
这里须要区分一下域名(或者 IP 地址)与 URL 的区别,域名肯定的是因特网中某台主机的位置;而 URL 则要更为具体,指某台主机中某个资源的具体位置。如 ttsy.com 是一个域名,经过这个域名能够找到其相对应 IP 地址的主机,而 ttsy.com/a/b.jpg 是一个 URL,经过这个 URL 能够找到这台主机上的路径为 /a 的 b.jpg 图片资源。图片
那么接下来详细介绍上述四个流程~ip
在咱们输入 URL 而且按下回车时,浏览器首先要作的即是经过域名查找对应的 IP 地址,这个过程也称做 DNS 解析。具体的查找过程以下:
浏览器得到 IP 地址后,就会对目标服务器发起创建 TCP 链接的请求,创建链接主要有三个步骤,通常称为客户端与服务器端的三次握手:
客户端与服务器创建链接后,便会开始进行通讯,这里以客户端向服务器请求网页资源的过程为例:
客户端与服务器的相互通讯完成后,便会断开链接,断开链接主要有四个步骤,通常称为客户端与服务器端的四次挥手:
为何客户端与服务器断开链接是四次挥手呢?主要是由于当客户端告诉服务器想断开链接的时候,服务器的数据不必定已处理完毕,因此服务器是先告诉客户端说已经收到了它想断开链接的请求,而后当服务器中数据处理完毕时,便通知客户端并请求断开链接,客户端收到后便断开链接并通知服务器,服务器收到后才断开链接。
以为还不错的小伙伴,能够关注一波公众号哦。