《深入分析JavaWeb技术内幕》读书笔记

简介: 《深入分析JavaWeb技术内幕》读书笔记  一.Web请求过程与架构 转载自:http://blog.csdn.net/jobsandczj/article/category/6885435 最近拜读了大牛许令波大神的著作《深入分析JavaWeb技术内幕》,感觉颇有受益,决定写一写读书笔记,以作总结。

《深入分析JavaWeb技术内幕》读书笔记 

一.Web请求过程与架构

转载自:http://blog.csdn.net/jobsandczj/article/category/6885435

最近拜读了大牛许令波大神的著作《深入分析JavaWeb技术内幕》,感觉颇有受益,决定写一写读书笔记,以作总结。第一章,我们就来讲一讲Web请求过程

随着Web2.0时代的到来,互联网的网络架构已从传统的C/S架构转变为更加方便快捷的B/S架构。这种转变不是没有原因的,下面我们就来说说B/S架构的优点。

B/S:

主要从两方面来阐述B/S的有点:客户端服务端

客户端使用统一的浏览器(Browser)。由于浏览器具有统一性,他不需要特殊的配置和网络连接。有效地屏蔽了不同服务提供商提高给用户使用服务的差异性。另外最重要的一点是浏览器的易用性,能使用户更加轻松方便地使用,大大降低了学习门槛。

服务端(Server)基于统一的HTTP。和传统的C/S架构使用自己定义的应用层协议不同,B/S架构使用统一的HTTP。使用统一的HTTP也为服务提供商简化了开发模式。有很多现成的基于HTTP的服务器,不仅如此,连开发服务的通用框架都不需要单独开发,这大大降低了开发门槛,因此也出现了越来越多的互联网服务。

由此可见,B/S是基于HTTP的,那HTTP又是什么呢?它是如何建立连接的呢?

HTTP是应用层的一种采用无状态的短连接的通信方式。通常情况下,一次请求就完成了一次数据交互,通常也对应一个业务逻辑,然后这次通信连接就断开了。采用这种方式是为了能够同时服务更多的用户,因为当前互联网应用每天都会处理上亿的用户请求,不可能每个用户访问一次后就一直保持这个连接。

B/S网络架构:

目前的B/S网络架构大多采用下图形式:

以下是原文截图,关于一次请求的过程。



当然,不管网络架构如何变化,始终有一些固定不变的原则。

1.互联网上所有资源都要用一个URL来表示。URL是统一资源定位符,不要小看URL,他几乎包含了整个互联网架构的精髓。当然,这个精髓貌似正在受到Ajax的挑衅。

2.必须基于HTTP与服务端交互。(HTTPS只是在HTTP的基础上加了个安保措施SSL[Secure Socket Layer]安全套接层)

3.数据必须在浏览器中被展示。

那HTTP如何发起请求呢。其实发起HTTP请求和建立一个Socket连接区别不大。只不过outputStream.write写的二进制字节数据格式要符合HTTP格式要求。浏览器就是根据解析出来的IP地址和默认的80端口与远程服务器建立Socket连接,然后浏览器再根据这个URL组装成一个get类型的HTTP请求头发送到服务器。当然,这个过程我们完全可以自己模拟。

HTTP:

我们再来讲一讲HTTP解析


浏览器缓存机制

Ctrl+F5组合键刷新后,会在请求头加两个请求项。Pragma:no-cache和Cache-Control:no-cache。它们有什么作用呢?

DNS域名解析

DNS域名解析是浏览器请求的一个非常重要的过程。我们平时上网可能感觉不到DNS解析的存在,但一旦DNS解析出错,哪台根服务器坏了,那互联网会出些灾难。

DNS域名解析可以分成10步,其中任何一步完成了域名解析,就不再往下进行。

1.查看浏览器缓存

2.查看操作系统缓存

3.向LDNS(本地DNS服务器)发起请求

4.向Root Server(根域名服务器)发起请求

5.根域名服务器返回给本地域名服务器一个所查询的主域名服务器(gTLD Server)。gTLD是国际顶级域名服务器,如.com,.cn,.org等,全球只有13台左右。

6.本地服务器再向上一步返回的gTLD服务器发送请求。

7.接受请求的gTLD服务器查找并返回此域名对应的Name Server域名服务器。

8.Name Server域名服务器会查询存储的域名和IP的映射关系表。

9.返回IP,通常情况下也会返回一个TTL,LDNS缓存时间由TTL值控制。

10.LDNS把解析的结果返回给用户,用户也根据得到的TTL值将结果缓存在本地系统缓存中。

在实际域名解析过程中,可能还不止这10个步骤,如Name Server也可能有多级,或者有一个GTM来进行负载均衡控制,这都有可能会影响域名解析过程。

Linux和Windows都可以用nslookup命令来查询域名的解析结果。

CDN架构:

最后我们来讲一讲CDN架构

CDN也就是内容分布网络(Content Delivery Network),它是构筑在现有Internet上的一种先进的流量分配网络。

原文截图

通常的CDN架构:

负载均衡

负载均衡(Load Balance)就是对工作任务进行平衡,分摊到多个操作单元上执行,如图片服务器、应用服务器等,共同完成工作任务。他可以提高服务器响应速度和利用率,避免软件或者硬件模块出现单点失效,解决网络拥塞问题,实现地理位置无关性,为用户提供较一致的访问质量。

通常有三种负载均衡架构:链路负载均衡(通过DNS解析来完成)集群负载均衡(分硬件和软件)操作系统负载均衡(通过软中断或者硬件中断)

微信公众号【黄小斜】大厂程序员,互联网行业新知,终身学习践行者。关注后回复「Java」、「Python」、「C++」、「大数据」、「机器学习」、「算法」、「AI」、「Android」、「前端」、「iOS」、「考研」、「BAT」、「校招」、「笔试」、「面试」、「面经」、「计算机基础」、「LeetCode」 等关键字可以获取对应的免费学习资料。 


                     wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

相关文章
|
存储 缓存 算法
全网最硬核Java程序员必备底层知识(一)
全网最硬核Java程序员必备底层知识(一)
全网最硬核Java程序员必备底层知识(一)
|
设计模式 存储 Java
《深入分析Java Web技术内幕》深入之后的理解
## 0.前言 近期阅读了《深入分析Java Web技术内幕》这本书,书中涉及的知识点非常全面,让我对Java Web相关技术有了更加全面的认识,受益匪浅。这里跟大家分享下本人深入后印象比较深刻的几个点。 ## 1.NIO (Non-blocking IO) ### 1.1同步异步、阻塞非阻塞 - I/O交互中经常涉及同步/异步,阻塞/非阻塞。 - 要注意这两个是不同纬度
《深入分析Java Web技术内幕》深入之后的理解
|
消息中间件 架构师 NoSQL
Java面试很难?啃完阿里老哥这套Java架构速成笔记,我都能拿30K
最近有不少小伙伴在后台留言,说 Java 的面试越来越难了,尤其是技术面,考察得越来越细,越来越底层。
Java面试很难?啃完阿里老哥这套Java架构速成笔记,我都能拿30K
|
存储 算法 安全
Java面试问题集锦(上)
1、Struts2和SpringMVC的区别
240 0
Java面试问题集锦(上)
|
前端开发 Java 程序员
走进JavaWeb技术世界1:JavaWeb的由来和基础知识
本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下Star哈 文章首发于我的个人博客: www.how2playlife.com 本文是微信公众号【Java技术江湖】的《走进JavaWeb技术世界》其中一篇,本文部分内容来源于网络,为了把本文主题讲得清晰透彻,也整合了很多我认为不错的技术博客内容,引用其中了一些比较好的博客文章,如有侵权,请联系作者。
|
Java 应用服务中间件 nginx
史上最牛JAVA思维导图学习笔记从初级到架构
我做过有道云笔记、印象笔记,也写过博客,几十篇文章之后,发现对笔记分类整理很麻烦,查询不容易,往往自己写的内容都不愿意看一眼,后来用了思维导图,很好用,结构清晰,一目了然,又灵机一动把导图做成chm格式,你知道的API文档都是chm,离线状态下就以查看了。
2912 0
JavaWeb技术内幕七:JVM体系结构和工作方式
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/81501369 这位大侠,这是我的公众号:程序员江湖。
|
Java 应用服务中间件 容器
JavaWeb技术内幕六:深入分析classloader工作机制
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/81456439 这位大侠,这是我的公众号:程序员江湖。
|
架构师 Java 中间件
架构书籍推荐:Java中高级、架构师值得一读!
上周我们免费送出了6本关于Python的重量级技术书籍,推出后反响特别强烈,有一个和最后一名仅差了一个赞,不过我们还是额外加送了一本送给这位朋友,以资鼓励,从另一面也可以看出Java程序猿对Python的热爱程序。
2012 0
|
缓存 Java 数据格式
深入分析Java Web技术内幕(三)
Java 的I/O类库的基本结构 基于字节操作的I/O接口:inputStream和OutputStream 基于字符操作的I/O接口:Writer和Reader 基于磁盘操作的I/O接口:File 基于网络操作的I/O接口:Socket 前两组主要是传输数据的数据个数,后两组主要是传输数据的方式。
1051 0