概述一个页面从输入URL到页面加载完的过程


Posted in Javascript onDecember 16, 2016

过程概述

  • 浏览器查找域名对应的 IP 地址;
  • 浏览器根据 IP 地址与服务器建立 socket 连接;
  • 浏览器与服务器通信: 浏览器请求,服务器处理请求;
  • 浏览器与服务器断开连接。

以下为详细解析:

根据域名查找 IP 地址

概念解释

  • IP 地址:IP 协议为互联网上的每一个网络和每一台主机分配的一个逻辑地址。IP 地址如同门牌号码,通过 IP 地址才能确定一台主机位置。服务器本质也是一台主机,想要访问某个服务器,必须先知道它的 IP 地址;
  • 域名( DN ):IP 地址由四个数字组成,中间用点号连接,在使用过程中难记忆且易输入错误,所以用我们熟悉的字母和数字组合来代替纯数字的 IP 地址,比如我们只会记住 www.baidu.com(百度域名) 而不是 220.181.112.244(百度的其中一个 IP 地址);
  • DNS: 每个域名都对应一个或多个提供相同服务服务器的 IP 地址,只有知道服务器 IP 地址才能建立连接,所以需要通过 DNS 把域名解析成一个 IP 地址。

知道了上面的概念,大概就知道了想要获得服务器的门牌号码,需要先将域名转换成 IP 地址。转换过程如下(以查询 www.baidu.com 的 IP 地址为例,其中2、3、4步均在上一步未查询成功的情况下进行):

查找过程

1.浏览器搜索自己的 DNS 缓存(维护一张域名与 IP 地址的对应表);

2.搜索操作系统中的 DNS 缓存(维护一张域名与 IP 地址的对应表);

3.搜索操作系统的 hosts 文件( Windows 环境下,维护一张域名与 IP 地址的对应表);

4.操作系统将域名发送至 LDNS(本地区域名服务器,如果你在学校接入互联网,则 LDNS 服务器就在学校,如果通过电信接入互联网,则 LDNS 服务器就在你当地的电信那里。)LDNS 查询自己的 DNS 缓存(一般查找成功率在 80% 左右),查找成功则返回结果,失败则发起一个迭代 DNS 解析请求;

  • LDNS 向 Root Name Server (根域名服务器,其虽然没有每个域名的的具体信息,但存储了负责每个域,如 com、net、org等的解析的顶级域名服务器的地址)发起请求,此处,Root Name Server 返回 com 域的顶级域名服务器的地址;
  • LDNS 向 com 域的顶级域名服务器发起请求,返回 baidu.com 域名服务器地址;
  • LDNS 向 baidu.com 域名服务器发起请求,得到 www.baidu.com 的 IP 地址;

5.LDNS 将得到的 IP 地址返回给操作系统,同时自己也将 IP 地址缓存起来;

6.操作系统将 IP 地址返回给浏览器,同时自己也将 IP 地址缓存起来;

7.至此,浏览器已经得到了域名对应的 IP 地址。

补充说明

  • 域名与 URL 是两个概念:域名是一台或一组服务器的名称,用来确定服务器在 Internet 上的位置;URL 是统一资源定位符,用来确定某一个文件的具体位置,例如,zhihu.com 是 知乎的域名,根据这个域名可以找到知乎的服务器,zhihu.com/people/CompileYouth 是 URL ,可以根据这个 URL 定位我的知乎主页;
  • IP 地址与域名不是一一对应的关系:可以把多个提供相同服务的服务器 IP 设置为同一个域名,但在同一时刻一个域名只能解析出一个 IP地址;同时,一个 IP 地址可以绑定多个域名,数量不限;

建立连接--三次握手

知道了服务器的 IP 地址,下面便开始与服务器建立连接了。

通俗地讲,通信连接的建立需要经历以下三个过程:

  • 主机向服务器发送一个建立连接的请求(您好,我想认识您);
  • 服务器接到请求后发送同意连接的信号(好的,很高兴认识您);
  • 主机接到同意连接的信号后,再次向服务器发送了确认信号(我也很高兴认识您),自此,主机与服务器两者建立了连接。

补充说明

  • TCP 协议:三次握手的过程采用 TCP 协议,其可以保证信息传输的可靠性,三次握手过程中,若一方收不到确认信号,协议会要求重新发送信号。

网页请求与显示

当服务器与主机建立了连接之后,下面主机便与服务器进行通信。网页请求是一个单向请求的过程,即是一个主机向服务器请求数据,服务器返回相应的数据的过程。

1.浏览器根据 URL 内容生成 HTTP 请求,请求中包含请求文件的位置、请求文件的方式等等;

2.服务器接到请求后,会根据 HTTP 请求中的内容来决定如何获取相应的 HTML 文件;

3.服务器将得到的 HTML 文件发送给浏览器;

4.在浏览器还没有完全接收 HTML 文件时便开始渲染、显示网页;

5.在执行 HTML 中代码时,根据需要,浏览器会继续请求图片、CSS、JavsScript等文件,过程同请求 HTML ;

断开连接--四次挥手

1.主机向服务器发送一个断开连接的请求(不早了,我该走了);

2.服务器接到请求后发送确认收到请求的信号(知道了);

3.服务器向主机发送断开通知(我也该走了);

4.主机接到断开通知后断开连接并反馈一个确认信号(嗯,好的),服务器收到确认信号后断开连接;

补充说明

  • 为什么服务器在接到断开请求时不立即同意断开:当服务器收到断开连接的请求时,可能仍然有数据未发送完毕,所有服务器先发送确认信号,等所有数据发送完毕后再同意断开。
  • 第四次握手后,主机发送确认信号后并没有立即断开连接,而是等待了 2 个报文传送周期,原因是:如果第四次握手的确认信息丢失,服务器将会重新发送第三次握手的断开连接的信号,而服务器发觉丢包与重新发送的断开连接到达主机的时间正好为 2 个报文传输周期。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript OOP面向对象介绍
Dec 02 Javascript
浅析jQuery对select操作小结(遍历option,操作option)
Jul 04 Javascript
js中函数调用的两种常用方法使用介绍
Jul 17 Javascript
JS中正则表达式只有3种匹配模式(没有单行模式)详解
Jul 28 Javascript
AngularJS通过$sce输出html的方法
Sep 22 Javascript
Jquery EasyUI Datagrid右键菜单实现方法
Dec 30 Javascript
关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的使用详解
May 12 Javascript
微信小程序新增的拖动组件movable-view使用教程
May 20 Javascript
vue观察模式浅析
Sep 25 Javascript
详解如何用VUE写一个多用模态框组件模版
Sep 27 Javascript
深入学习Vue nextTick的用法及原理
Oct 08 Javascript
微信小程序利用for循环解决内容变更问题
Mar 05 Javascript
详解MVC如何使用开源分页插件(shenniu.pager.js)
Dec 16 #Javascript
js继承实现方法详解
Dec 16 #Javascript
详解jQuery简单的表格应用
Dec 16 #Javascript
JS中parseInt()和map()用法分析
Dec 16 #Javascript
HTML5canvas 绘制一个圆环形的进度表示实例
Dec 16 #Javascript
JS数字千分位格式化实现方法总结
Dec 16 #Javascript
jquery插件锦集【推荐】
Dec 16 #Javascript
You might like
如何取得中文字符串中出现次数最多的子串
2013/08/08 PHP
Laravel执行migrate命令提示:No such file or directory的解决方法
2016/03/16 PHP
jquery下组织javascript代码(js函数化)
2010/08/25 Javascript
简单实用的js调试logger组件实现代码
2010/11/20 Javascript
jquery miniui 教程 表格控件 合并单元格应用
2012/11/25 Javascript
使用jQuery避免鼠标双击的解决方案
2013/08/21 Javascript
开发中可能会用到的jQuery小技巧
2014/03/07 Javascript
谈谈对offsetleft兼容性的理解
2015/11/11 Javascript
bootstrap datetimepicker实现秒钟选择下拉框
2017/01/05 Javascript
Vue动态实现评分效果
2017/05/24 Javascript
详解Vue组件之间的数据通信实例
2017/06/17 Javascript
JS实现的全排列组合算法示例
2017/10/09 Javascript
基于Vue实现微信小程序的图文编辑器
2018/07/25 Javascript
jQuery表单选择器用法详解
2019/08/22 jQuery
layui.use模块外部使用其内部定义的js封装函数方法
2019/09/16 Javascript
python基础教程之基本数据类型和变量声明介绍
2014/08/29 Python
Python中字典映射类型的学习教程
2015/08/20 Python
好用的Python编辑器WingIDE的使用经验总结
2016/08/31 Python
使用Flask集成bootstrap的方法
2018/07/24 Python
解决pycharm无法识别本地site-packages的问题
2018/10/13 Python
Python实现的列表排序、反转操作示例
2019/03/13 Python
Python弹出输入框并获取输入值的实例
2019/06/18 Python
springboot配置文件抽离 git管理统 配置中心详解
2019/09/02 Python
Python FFT合成波形的实例
2019/12/04 Python
Python实现点云投影到平面显示
2020/01/18 Python
python3实现语音转文字(语音识别)和文字转语音(语音合成)
2020/10/14 Python
python opencv实现图像配准与比较
2021/02/09 Python
巧用 CSS3的webkit-box-reflect 倒影实现各类动效
2021/03/05 HTML / CSS
12岁生日感言
2014/01/21 职场文书
《第一次抱母亲》教学反思
2014/04/16 职场文书
安全负责人任命书
2014/06/06 职场文书
2015年幼儿园班主任工作总结
2015/05/12 职场文书
篮球赛闭幕式主持词
2015/07/03 职场文书
MySQL多表查询机制
2022/03/17 MySQL
关于Mybatis中SQL节点的深入解析
2022/03/19 Java/Android
Redis主从复制操作和配置详情
2022/09/23 Redis