很多事情看起来都很简单,但是却从来没去剖析背后的本质,没有去深入的了解。导致我们在生活中或者工作上总是会被同样的问题所困惑。
如何发起一个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地址。
所以说,从一个平时的普通现象去分析,可以得到许多想不到的细节,在工作中和生活上更应该如此。磨刀不误砍柴工。