第一章:深入web请求过程
初学者,总结一下读书笔记,望海涵。
1.1 B/S网络架构概述
相比于C/S架构,B/S网络架构(Browser/Server)从前端到后端都得到了简化,都基于统一的应用层协议HTTP来交互数据,采用无状态的短连接来交互数据。
当一个用户在浏览器里输入网址时,会发生很多操作:
1.请求DNS把域名解析成对应的Ip地址
2.根据ip地址在互联网上找到对应的服务器
3.向服务器发起get请求,服务器返回数据资源给访问的用户。
4.数据返回浏览器时,若解析资源发现还有一些静态资源(css,js或图片),会再次发起HTTP请求。
5.发起的HTTP请求很可能会在CDN上,CDN服务器又会开始处理请求。
网络架构遵循的原则:
1.URL,统一资源定位符。互联网上所有资源都要用一个URL表示。
2.必须基于HTTP与服务端交互。
3.数据展示必须在浏览器中进行。
1.2 如何发起一个请求
发起一个HTTP请求的过程就是建立一个Socket通信的过程。(可以通过HttpClient来模拟)。
1.3 HTTP解析
B/S网络架构的核心就是HTTP。
HTTP Header控制着用户浏览器的渲染行为和服务器的执行逻辑。
可以通过F12查看HTTP请求的请求头和响应头。
查看HTTP信息的工具:Firebug HttpFox
当我们刷新一个页面时,在HTTP请求头中会增加一些请求头,它告诉服务端我们要获取最新数据而不是缓存。
在请求头增加了两个请求项:Pragma:no-cache 和 Cache-Control:no-cache
Expires 后面跟着一个日期和时间,超过这个时间值后,缓存的内容将失效。
Last-Modefied/Etag 表示一个服务器上资源的最后修改时间。Etag 给每个页面分配唯一的编号,通过编号区分当前页面是否是最新的。
1.4 DNS域名解析
1.浏览器检查缓存中有无这个域名对应的解析过的ip地址。有则结束,无则进行下一步。
2.浏览器查找操作系统缓存中是否有这个域名对应的DNS解析结果。有则结束,无则进行下一步。
3.操作系统会把这个域名发送给这里设置的local DNS Server(本地域名服务器),例:学校,电信,联通。有则结束,无则进行下一步。
4.直接到Root Server域名服务器(根域名服务器)请求解析。
5.根域名服务器会返回给本地域名服务器一个所查询域的主域名服务器(gTLD Server,国际顶级服务器,全球13台)。
6.本地域名服务器向gTLD server发起请求
7.gTLD server查找并返回此域名对应的Name Server域名服务器地址(通常为所注册的域名服务器)
8.Name Server查询存储的域名和ip的映射关系表
9.Name Server将ip和TTL一起返回给本地域名服务器。
10.本地域名服务器将解析的结果返回给用户。用户根据TTL值缓存在本地系统缓存中。
可以用nslookup查询域名的解析结果。
ipconfig /flushdns 刷新缓存。
JVM也会缓存DNS的解析结果,在InetAddress类中完成。若要用InetAddress类解析域名,必须采用单例模式。
域名解析记录主要分为:A记录,MX记录,CNAME记录,NS记录,TXT记录
1.5 CDN工作机制
CDN,内容分布网络,构筑在现有internet上的一种先进的流量分配网络,其目的是通过现有的Internet中增加一层新的网络架构。使用户可以就近取得所需内容,提高用户访问网站的速度。
目前CDN以缓存网站中的静态数据为主。用户在从主站服务器请求到动态内容后,再从CDN上下载这些静态数据。从而加速网页数据内容的下载速度。
CDN:可扩展;安全性;可靠性、相应和执行。
CDN架构:
用户访问某静态css文件
1.2在用户本机上完成。
3.向本地域名服务器发起请求。
......迭代解析
7.在Name Server中,重新cname了另一个域名,查询到对应的Ip后,返回给本地域名服务器。
8.本地域名服务器向CDN中的DNS解析发起请求
9.CDN的DNS解析向GTM发起请求。
10.GTM来最终分配是哪个地方的访问用户。
11.GTM返回给本地域名服务器离这个 访问用户最近的CDN结点。
12.本地域名服务器将ip返回给用户。
13.拿到了返回的ip,用户就可以直接去CDN节点访问静态文件了。(访问CDN会经过许多CDN节点,去源站拿到数据后会返回)
负载均衡架构:链路负载均衡,集群负载均衡,操作系统负载均衡。
CDN动态加速:在CDN的DNS解析中,通过动态的链路探测来寻找回源最好的一条路径,然后通过DNS的调度将所有请求调度到选定的这条路径上回源,从而加速用户的访问效率。
由于CDN节点是遍布全国的,所以用户接入一条CDN节点后,可以选择一条离用户最近的CDN节点到源站链路最好的路径让用户走。
第一章:深入web请求过程的更多相关文章
- 第一章 深入web请求过程
		B/S架构的的好处: 客户端使用统一的浏览器(browser).由于浏览器的统一性,它不需要特殊的配置和网络连接,有效的屏蔽了不同服务提供商提供给用户使用服务的差异性.另外一点是浏览器的交互特性使得用 ... 
- 第一章 深入Web请求过程(待续)
		B/S网络架构概述 如何发起一个请求 HTTP解析 DNS域名解析 CDN工作机制 
- 《深入分析Java Web技术内幕》读书笔记 - 第1章 深入Web请求过程
		第1章 深入Web请求过程 1 1.1 B/S网络架构概述 2 基于统一的应用层协议HTTP来交互数据. 1.2 如何发起一个请求 4 HTTP连接本质是建立Socket连接.请求实现方式:工具包如H ... 
- 第一章 了解Web及网络基础
		第一章 了解Web及网络基础 Web建立基础.HTTP如何诞生发展 1.使用HTTP协议访问Web 在浏览器地址栏中输入URL之后过程: 1)DNS 解析:浏览器查询 DNS,获取域名对应的 IP 地 ... 
- 第一章   创建WEB项目
		第一章 创建WEB项目 一.Eclipse创建WEB项目 方法/步骤1 首先,你要先打开Eclipse软件,打开后在工具栏依次点击[File]>>>[New]>>&g ... 
- Http协议简单解析及web请求过程
		HTTP协议: HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统. 基于HTTP协议的客户端/服务器请求响应机制的信息交换过程包含下面几个步骤: 1) ... 
- Web请求过程总结
		Web请求过程总结 1.CND架构图 图片来源:深入分析JavaWeb技术内幕(许令波著) 2.发起HTTP请求 发起一个HTTP请求就是浏览器建立socket通信的过程,HttpClient开源的通 ... 
- 爬取百度页面代码写入到文件+web请求过程解析
		一.爬取百度页面代码写入到文件 代码示例: from urllib.request import urlopen #导入urlopen包 url="http://www.baidu.com& ... 
- web请求过程-学习使人快乐1
		智齿离开我10个小时了,现在除了书啥都不能啃········呜呜呜~ ~~~~~~~~~~~~~~~~~~~想滑滑梯~~~~~~~~~~~~~~~~~~~ 网络请求过程 web请求大多使用B/ ... 
- 1 深入Web请求过程
		1.1 B/S网络架构概述 B/S 网络架构从前端到后端都得到了简化,都基于统一的应用层协议HTTP来交互数据,与大多数传统C/S互联网应用程 序采用的长连接的交互模式不同,HTTP采用无状态的短连接 ... 
随机推荐
- django 2.1 配sql server 2008R2
			请教了不少高手和度娘终于把这个事搞定了(基本上断断续续查试了2周时间),,,,,,,, 环境: 1-Microsoft Windows 2-Microsoft SQL SERVER2008 ... 
- 数据挖掘算法——Close算法
			说明奥:菜鸟的自我学习,可能有错. Close算法原理: 一个频繁闭合项目集的所有闭合子集一定是频繁的,一个非频繁闭合项目集的所有闭合超集一定是非频繁的. close算法是对Apriori算法的改进 ... 
- 多条件搜索优化sql
			SELECT ctm.* FROM crawltaskmanage ctm,urlmanage um WHERE (ctm.status='0' AND um.`urlId`=ctm.`urlId`) ... 
- nodejs笔记之初识node
			1.安装node; node -v //检测node是否安装成功 node可以做什么: 搭建服务器: 读写文件: 连接数据库: 爬虫: node的模块系统: 原生模块(如http,fs); 自定义模 ... 
- List添加map,后添加的map覆盖前面的问题
			List resultList = new ArrayList(); Map map = new HashMap(); while(rs.next()){ String userid = rs.get ... 
- SCI_Call_Bsw_SetPwmMotorGroupB
			Sci_Bsw.c -- definition MotorGroupB_cfg.c -- called in LatchControl_Magna.c: extern uint16 Sci_DRead ... 
- saltstack 安装
			centos 6.5 saltstack 2015.5.10 (Lithium) tips:上个版本2015.5.3或者5.5有个bug,Python调用salt的unzip模块报错: 安装 在配置了 ... 
- 3. Dubbo原理解析-Dubbo内核实现之动态编译 (转)
			转载自 斩秋的专栏 http://blog.csdn.net/quhongwei_zhanqiu/article/details/41577159 我们运行的Java代码,一般都是编译之后的字节码 ... 
- yaf
			一.yaf使用自定义的类 Yaf的library和model的文件命名规则和调用:https://www.cnblogs.com/leedom/p/9396138.html 安装参考: https:/ ... 
- Build Tool
			building tool: 一.building tools 为什么主流? Gradle 是目前比较流行的构建工具之一,Android Studio 中集成的就是 Gradle,并针对 Androi ... 
