30 | 时代之风(上):HTTP/2特性概览
30 | 时代之风(上):HTTP/2特性概览
讲述:Chrono
时长11:04大小12.66M
为什么不是 HTTP/2.0
兼容 HTTP/1
头部压缩
二进制格式
虚拟的“流”
强化安全
协议栈
小结
课下作业
赞 15
提建议
精选留言(32)
- 俊伟2020-01-191.h2c使用明文传输,速度更快,不需要TLS握手。 2.客户端将多个请求分成不同的流,然后每个流里面在切成一个个帧,发送的时候是按帧发送的。每个帧存着一个流ID来表示它属于的流。服务端收到请求的时候将帧按流ID进行拼接。从传输的角度来看流是不存在的,只是看到了一个个帧,所以说流是虚拟的。 3.相同点:都是基于TCP和TLS的,url格式都是相同的。都是基于header+body的形式。都是请求-应答模型。 4.不同点: 1.使用了HPACK进行头部压缩。 2.使用的是二进制的方式进行传输。 3.将多个请求切分成帧发送,实现了多路复用。这个感觉上利用了多道程序设计的思想。 4.服务器可以主动向客户端推送消息。充分利用了TCP的全功双通道。展开
作者回复: 总结的非常好,great。
共 2 条评论42 - magicnum2019-08-05h2c优点是性能,不需要TLS握手以及加解密。可以通过curl工具构造h2c请求; h2的流是虚拟的因为它是使用帧传输数据的,相同streamid的帧组成了虚拟消息以及流; 相同点:都是基于tcp或TLS,并且是基于请求-响应模型,schema还是http或https不会有http2。 不同点:h2使用二进制传输消息并且通过HPACK压缩请求头,实现流多路复用、服务器推送展开
作者回复: great!
共 3 条评论26 - 阿锋2019-08-05突然想起了一个问题,get和post请求其中一个区别是,post请求会把请求的数据放入请求体(body)中,而get请求是拼接到url后面。get请求是不是一定不能往请求体(body)中放入数据。还是这些都只是客户端和服务端的约定,可以灵活的自定义,没有强制的要求。
作者回复: get也可以有body,post也可以用query参数,区别的关键在于动作语义,一个是取一个是存。
共 3 条评论13 - nb Ack2019-08-05老师好。我想问一下,http2的多路复用和http的长连接效果不是一样吗?
作者回复: 完全不一样。 多路复用多个请求没有顺序,而长连接多个请求必须排队,就会队头阻塞。 可以再看看示意图体会一下。
12 - 夏目2019-12-09流就是逻辑上将数据帧按id分组了,同组有序,组间无序,本质就是id相同的几个数据帧所以流是虚拟的。在tcp层面还是队首阻塞的吧?需要等待ack
作者回复: 是的,理解的非常正确。
8 - Maske2020-06-261.明文传输时不需要进行加密解密动作,不需要TLS握手,能节约性能。适用于对数据传输安全性要求不高的场景。 2.http2改变了http1.1的“请求-应答”模式,将head+body的请求报文在传输过程中改为 head帧 + data帧,在同一个TCP/IP中,可以将多个请求分解为多个帧,从连接层面来看,这些帧是无序的,为了让接受端准确的将这些帧还原为一个一个独立的请求或响应,就给了每一个帧分配了streamid,streamid相同的即为同一个请求或响应的数据。因此,此处的流并不是真实有序的二进制字节,所以叫‘虚拟流’。 3.http1.1解决的是在万维网中,计算机之间的信息通信的一套规范,包括定义其属于应用层协议,建立在tcp/ip之上,请求响应的报文结构等。https不改变http1.1的原有属性,是在其之上新增了对数据安全性和有效性的特性,解决的是数据安全的问题,通过使用加密解密,数字证书,TLS握手等过程保证了这一点。http2解决的是性能问题,通过头部压缩,使用二进制传输,多路复用,服务器推送等策略使得http的性能更好。http2和https本质上都是对http1.1的扩展和延伸。展开
作者回复: 理解的很透彻,great。
7 - -W.LI-2019-08-05课后习题出的很好。可惜我不会坐等答案 1.内网用h2c会比https快么? 2.感觉回答虚拟流之前给先回答啥是真真的流。我对流的理解是有序,切只能读一次。http2支持乱序发,我猜也支持,部分帧重发,所以就是虚拟的了。 3.共同,都是应用层协议,传输成都用的TCP。 不同:https=TLS+HTTP/HTTP2,安全。 http2:二进制传输,对header压缩,通过二进制分帧解决了队头阻塞,传输效率更高,服务端可推数据 http:明文,队头阻塞,半双工。 问题1:一个TCP链接可以打开很多channel是吧,每一个channel都可以传输数据。底层具体怎么实现的啊,是怎么区分channel里的数据谁是谁的? 问题2:我之前看见TPC好像是通过服务端IP,服务端端口号,客户端端IP,客户端端口号。来唯一标识一个链接的。http1的时候队头阻塞,继续要多建http链接。每建立一个链接客户端就用一个不同的端口号么?展开
作者回复: 1.当然,省去了加密的成本。 2.所谓“虚拟的流”,是指流实际上是多个同一序号的帧,并没有真正的流数据结构,这与连接不同。 3.正确。 4.你说的channel应该是http/2里的“流”吧,http/2里没有channel。流是由帧组成的,帧头里有流id标记所属的流,马上会讲具体的细节。 5.标记一个tcp连接要用四元组(客户端ip端口+服务器ip端口),所以肯定要用一个新的端口号,在客户端这是临时分配的,而服务器是固定的端口。
共 3 条评论7 - 渴望做梦2019-08-29老师,我有个疑问,既然http2是二进制的格式,那我们还能用chrome自带的工具调试吗?
作者回复: 可以的,Chrome会把二进制解码,还原为http/1的文本形式,你可以自己试一下。
6 - 潇潇雨歇2020-11-301、明文传输性能更好,省去了加密相关操作 2、流和请求/应答一样,但是流是相同流id的帧组合,不同流可以无序,相同流有序。整个看起来是无序的,请求之间不受影响。这也解决了http1.1的队头阻塞。 3、三者都是基于tcp的,基本语义是一样的。http2在性能上做了提升,比如二进制帧,流,服务器推送,HPACK算法等;https在安全上做了提升,下层多了TLS/SSL,要多做一些握手加密证书验证等操作。展开
作者回复: 回答的非常好!
5 - BoyiKia2020-05-18http2 优点 1.兼容性 兼容以前的http1.1 ,https等。 2.性能提升 报文变成了 二进制数据帧,提高传输效率,和减少歧义。 ①header 采用了头部压缩,来减小传输体积。 ②body数据 放到了 data帧。 a.同一请求或响应的数据帧具有相同的帧标识(流ID),两端接受到的帧数据可以通过同一帧标识,重新组装成请求或响应数据。 b.不同请求/响应的数据帧可以乱序发,避免生成请求队列造成的队头阻塞。 c.同一个TCP连接上,可以并行发送多种流的数据帧(多路复用,PS: http1的 多路复用是分母效应,同一连接串行增加http通信 )。 d.强化了请求响应模式,服务器可以主动发送信息-服务器推送。 3.安全性 ①.要求下层必须是 TlS1.2以上,支持前向安全,废除安全性比较低的密码套件。展开
作者回复: awesome!
4 - 兔嘟嘟2021-07-29老师好,我不太理解为什么二进制帧可以提高解析效率,我的理解是这样的: 在HTTP/1.1中,请求方的字符串在TCP层被解码为Unicode二进制,然后应答方在HTTP层编码为utf-8字符串。 而在HTTP/2中,请求方的字符串在HTTP层被解码为二进制,然后应答方在浏览器处编码为字符串。所以好像没有省去时间或者资源。请老师赐教
作者回复: 二进制的好处显而易见,用位来表示信息,要比字符串表示简单,比如用01表示host,而用字符串就需要4个字节,而且要用状态机去检测单词,非常麻烦。 http/2在底层是二进制,解析起来快速方便,然后再到应用层对字符串做个映射就行了,不是再编码。 可以再用hpack来理解一下。
共 3 条评论3 - Maske2020-11-20老师我又回来了,按之前的理解是,http2是对同一域名使用单一的TCP连接进行数据传输,多个请求同时进行,既然如此,为什么在chrome调试面板中还能看到资源还是是有请求排队时间的呢?
作者回复: http/2里面的流,就相当于http/1里的并发连接,要开一个新流同样也要有一些准备的工作。Chrome里的排队属于它自己的调度工作,与http/2协议是无关的。
3 - 谢一2019-09-09老师,既然在连接层,是无序的,那在http/2中是怎么保证frame的有序性的呢?
作者回复: tcp层是有序的,所以一个流里的多个帧会按照顺序依次到达,接收方只要依次接收就可以了。
共 2 条评论3 - 疯琴2021-07-16请问老师,同一个流里面不同序号的帧可以乱序到达统一组装么?
作者回复: 不会的,tcp会保证有序送达,多个流是并行乱序发,但看单个流,它里面的帧还是有序的。
共 2 条评论2 - cake2022-06-24老师请问下,而在“连接”的层面上看,消息却是乱序收发的“帧”,为什么HTTP3 Over UDP 连接层面是包,这个HTTP2连接层面为啥是帧呢?不应该叫报文段么
作者回复: 我觉得这只是称呼的问题,都是一段段的数据,只是协议里起了个专用名词,把它的作用功能弄清楚就行了,不要太纠结名字。
1 - 思维决定未来2020-09-07http2的事实标准就是加密传输的,那是不是跟https重复了?
作者回复: 前面说过,对http的改进有两个方向,一个是安全,一个是效率,http/2是安全和效率兼顾,而https只是传输安全,效率上没有改进。
共 4 条评论1 - 路边的猪2023-02-13 来自辽宁想知道对于 HTTP/2 这种大的版本,以及包括之前的http/1.1 是怎么一步步在全世界范围内被广泛应用的?协议颁发出来,是会有一些大头企业领头去实现基于HTTP/2的协议吗?
作者回复: 是啊,http/2、http/3都是Google先做出个原型,然后在自家的Chrome里试用推广,再不断根据反馈修正,就成为了事实标准,最后提交IETF标准化。
- KaKaKa2023-01-10 来自北京老师,重新复习的时候,我突然有点疑惑: 1.同一个TCP连接中,多个流是怎么并发请求的?再怎么并发,不都是需要这个TCP连接去一个个数据包进行传输吗?那为什么还需要有多个流? 2.多个TCP连接,每个连接都能单独去发送数据包,这种形式不是更快吗? 本来我以为我了解这章了,现在重新复习的时候,有些点还是不太了解
作者回复: 1. 流是逻辑上的概念,实际上就是一些数据包,但这些包在tcp层面是无序的,也就解决了队头阻塞问题,在http/2层面把这些包整理成流,每个流对应一个http请求响应。 2.多个连接当然很快,但问题是服务器不允许客户端建立任意多的连接。 3.可以在看一下之前讲http/2历史的课程,理解它针对的痛点。
- Geek_68d3d22021-09-09请问同一个流可以在一个tcp连接里面发送吗
作者回复: 当然了,流实际上就是多个无序的数据帧,在tcp连接里乱序发送,到了目的地再按照序号组装,就形成了流。
- Mingyan2021-06-04我有疑问,http2.0如果遇到服务器主动关闭tcp链接会理会回ack,再发fin等ack去关闭tcp链接还是不理会继续使用被关闭的tcp链接了?
作者回复: tcp连接关闭后就消失了,再建连就是一个新的连接,不存在复用。