一次性搞懂 HTTP、HTTPS、SPDY、HTTP2

一次性搞懂 HTTP、HTTPS、SPDY、HTTP2,第1张

概述一次性搞懂 HTTP、HTTPS、SPDY、HTTP2 本篇文章给大家带来的内容是关于一次性搞懂 http、httpS、SPDY、http2,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

作为互联网通信协议的一员老将,http 协议走到今天已经经历了三次版本的变动,现在最新的版本是 http2.0,相信大家早已耳熟能详。今天就给大家好好介绍一下 http 的前世今生。

http/0.9

http 的最早版本诞生在 1991 年,这个最早版本和现在比起来极其简单,没有 http 头,没有状态码,甚至版本号也没有,后来它的版本号才被定为 0.9 来和其他版本的 http 区分。http/0.9 只支持一种方法—— Get,请求只有一行。

GET /hello.HTML
响应也是非常简单的,只包含 HTML 文档本身。

<HTML>Hello world</HTML>

当 TCP 建立连接之后,服务器向客户端返回 HTML 格式的字符串。发送完毕后,就关闭 TCP 连接。由于没有状态码和错误代码,如果服务器处理的时候发生错误,只会传回一个特殊的包含问题描述信息的 HTML 文件。这就是最早的 http/0.9 版本。

http/1.0

1996 年,http/1.0 版本发布,大大丰富了 http 的传输内容,除了文字,还可以发送图片、视频等,这为互联网的发展奠定了基础。相比 http/0.9,http/1.0 主要有如下特性:

请求与响应支持 http 头,增加了状态码,响应对象的一开始是一个响应状态行

协议版本信息需要随着请求一起发送,支持 head,POST 方法

支持传输 HTML 文件以外其他类型的内容

一个典型的 http/1.0 的请求像这样:

GET /hello.HTML http/1.0User-Agent:NCSA_Mosaic/2.0(windows3.1)200 OKDate: Tue, 15 Nov 1996 08:12:31 GMTServer: CERN/3.0 libwww/2.17Content-Type: text/HTML<HTML>一个包含图片的页面<imgSRC="/smile.gif"></HTML>

http/1.1


在 http/1.0 发布几个月后,http/1.1 就发布了。http/1.1 更多的是作为对 http/1.0 的完善,在 http1.1 中,主要具有如下改进:

可以复用连接

增加 pipeline:http 管线化是将多个 http 请求整批提交的技术,而在传送过程中不需先等待服务端的回应。管线化机制须通过永久连接(persistent connection)完成。浏览器将http请求大批提交可大幅缩短页面的加载时间,特别是在传输延迟(lag/latency)较高的情况下。有一点需要注意的是,只有幂等的请求可以使用 pipeline,如 GET,head 方法。

chunked 编码传输:该编码将实体分块传送并逐块标明长度,直到长度为 0 块表示传输结束, 这在实体长度未知时特别有用(比如由数据库动态产生的数据)

引入更多缓存控制机制:如 etag,cache-control

引入内容协商机制,包括语言,编码,类型等,并允许客户端和服务器之间约定以最合适的内容进行交换

请求消息和响应消息都支持 Host 头域:在 http1.0 中认为每台服务器都绑定一个唯一的 IP 地址,因此,请求消息中的URL并没有传递主机名(hostname)。但随着虚拟主机技术的发展,在一台物理服务器上可以存在多个虚拟主机(Multi-homed Web Servers),并且它们共享一个 IP 地址。因此,Host 头的引入就很有必要了。

新增了 OPTIONS,PUT, DELETE, TRACE, CONNECT 方法

虽然 http/1.1 已经优化了很多点,作为一个目前使用最广泛的协议版本,已经能够满足很多网络需求,但是随着网页变得越来越复杂,甚至演变成为独立的应用,http/1.1 逐渐暴露出了一些问题:

在传输数据时,每次都要重新建立连接,对移动端特别不友好

传输内容是明文,不够安全

header 内容过大,每次请求 header 变化不大,造成浪费

keep-alive 给服务端带来性能压力

为了解决这些问题,httpS 和 SPDY 应运而生。

SPDY

其实 SPDY 并不是新的一种协议,而是在 http 之前做了一层会话层。

在 2010 年到 2015 年,谷歌通过实践一个实验性的 SPDY 协议,证明了一个在客户端和服务器端交换数据的另类方式。其收集了浏览器和服务器端的开发者的焦点问题,明确了响应数量的增加和解决复杂的数据传输。在启动 SPDY 这个项目时预设的目标是:

页面加载时间 (plt) 减少 50%。

无需网站作者修改任何内容。

将部署复杂性降至最低,无需变更网络基础设施。

与开源社区合作开发这个新协议。

收集真实性能数据,验证这个实验性协议是否有效。

为了达到降低目标,减少页面加载时间的目标,SPDY 引入了一个新的二进制分帧数据层,以实现多向请求和响应、优先次序、最小化及消除不必要的网络延迟,目的是更有效地利用底层 TCP 连接。

http/2.0

时间来到 2015 年,http/2.0 问世。先来介绍一下 http/2.0 的特点吧:

使用二进制分帧层:在应用层与传输层之间增加一个二进制分帧层,以此达到在不改动 http 的语义,http 方法、状态码、URI 及首部字段的情况下,突破http1.1 的性能限制,改进传输性能,实现低延迟和高吞吐量。在二进制分帧层上,http2.0 会将所有传输的信息分割为更小的消息和帧,并对它们采用二进制格式的编码,其中 http1.x 的首部信息会被封装到 headers 帧,而我们的 request body 则封装到 Data 帧里面。

二进制分帧

多路复用:对于 http/1.x,即使开启了长连接,请求的发送也是串行发送的,在带宽足够的情况下,对带宽的利用率不够,http/2.0 采用了多路复用的方式,可以并行发送多个请求,提高对带宽的利用率。

多路复用

数据流优先级:由于请求可以并发发送了,那么如果出现了浏览器在等待关键的 CSS 或者 Js 文件完成对页面的渲染时,服务器却在专注的发送图片资源的情况怎么办呢?http/2.0 对数据流可以设置优先值,这个优先值决定了客户端和服务端处理不同的流采用不同的优先级策略。

服务端推送:在 http/2.0 中,服务器可以向客户发送请求之外的内容,比如正在请求一个页面时,服务器会把页面相关的 logo,CSS 等文件直接推送到客户端,而不会等到请求来的时候再发送,因为服务器认为客户端会用到这些东西。这相当于在一个 HTML 文档内集合了所有的资源。

头部压缩:使用首部表来跟踪和存储之前发送的键值对,对于相同的内容,不会再每次请求和响应时发送。

总结

以上是内存溢出为你收集整理的一次性搞懂 HTTP、HTTPS、SPDY、HTTP2全部内容,希望文章能够帮你解决一次性搞懂 HTTP、HTTPS、SPDY、HTTP2所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1012219.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存