深入Web请求过程

很多事情看起来都很简单,但是却从来没去剖析背后的本质,没有去深入的了解。导致我们在生活中或者工作上总是会被同样的问题所困惑。
如何发起一个web的请求,这是一个既简单又复杂的问题,简单是我们只要在浏览器里输入一个链接按回车就发起了,过一会就能看到这个链接的返回结果。复杂是说这个链接从发起到返回页面这之间经历了一个怎样的过程。

记得我在学习JavaSE那部分内容的时候,有一章节是关于讲网络编程的,其中就讲到了socket编程,当时我为了实现一个简单的聊天室的程序,熬战了一个礼拜,当时的主要解决几个问题,第一就是客户端和服务端应该怎么设计,第二就是两者之间的通信协议怎么定。在编写这个程序的时候,自己制定了客户端和服务端之间的通信协议,服务端单独启动一个线程专门监听客户端发送过来的消息,然后我在服务端专门制定了一套消息的解析规则。


说到这个是因为http请求也和socket类似,http协议是互联网的一种标准通用协议。浏览器发起连接也是会建立socket链接,只不过用outputStream.write的数据格式必须符合http格式。所以发起一个HTTP链接,本质上就是建立一个socket的过程。

1.当我们输入一个链接的时候。比如www.cs-icloud.gov.cn这个域名,浏览器会首先检查缓存中有没有这个域名对应的解析过的IP地址,不然每次都去寻址,可想而知会多影响效率,也别是互联网追求速度和效率。当然如果缓存中有这个域名的解析地址,那么解析过程也就到此结束。

2.当用户浏览器缓存中没有发现这个域名的时候,则再去操作系统的系统缓存中查找这个是否有这个解析过的域名。还有一个就是windows的host文件,原来这个文件可以将任何的域名指向到任何能够访问的IP地址,如果这个文件里指定了,那么浏览器就会直接就访问这个IP地址,所以正是由于这种本地解析的机制,很容易被黑客通过修改本地host文件的形式来进行域名劫持。

3如果本机的缓存还是没有的话,那么接下来会去请求本地域名解析服务器LDNS,这个服务器的地址就是我们在网络设置里看到的DNS服务器地址。这个地址通常就是我们的网络服务提供商给我们的。也就是平时的电信联通之类的服务商。这台服务器一般就在我们所在城市的某个地方。不会太远。这个专门的域名解析服务器性能会很好,一般会缓存解析过的结果,当然缓存的时间是有限的。这个比较好理解,因为有时候这个域名会指向别的IP地址,如果一直缓存的话或者时间比较长,会导致这个域名不能解析道对应的IP地址上面,导致无法解析。

4.到了这,如果在LDNS还不能命中的话,则会直接请求根服务器了,根服务器会给LDNS返回一个查询的主域名服务器,叫做gLTD,这是一台国际顶级域名服务器,全球只有十三台左右。

5.顶级域名服务器找到资源后就会把解析结果返回,浏览器就能正确访问到对应的IP地址。

所以说,从一个平时的普通现象去分析,可以得到许多想不到的细节,在工作中和生活上更应该如此。磨刀不误砍柴工。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • B/S 架构的好处 客户端使用同一的浏览器。浏览器具有统一性,不需要特殊的配置和网络连接,屏蔽了服务的差异性。 浏...
    七弦桐语阅读 3,273评论 0 4
  • 最近,终于要把《WEB请求处理系列》提上日程了,一直答应小伙伴们给分享一套完整的WEB请求处理流程:从浏览器、Ng...
    七寸知架构阅读 31,856评论 27 253
  • 上一篇《WEB请求处理一:浏览器请求发起处理》,我们讲述了浏览器端请求发起过程,通过DNS域名解析服务器IP,并建...
    七寸知架构阅读 81,313评论 21 356
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,079评论 19 139
  • 1、序列图的定义 序列图是对对象之间传送消息的时间顺序的可视化表示。 序列图的主要用途是把用例表达的需求,转化为进...
    王皮皮_阅读 1,834评论 0 3