HTTP2.0

1.起源

  • 在现有的互联网设置基础和http协议广泛使用的前提下,是可以通过修改协议层来优化http1.x的
  • 针对http1.x的修改确实效果明显而且业界反馈很好(SPDY)

所以,IETF开始正式考虑制定HTTP2.0,最后决定以SPDY/3为蓝图起草HTTP2.0

2.需要思考的问题

  • HTTP的不足

1)单路连接,请求低效
HTTP 协议的最大弊端就是每个 TCP 连接只能对应一个 HTTP 请求,即每个 HTTP 连接只请求一个资源,浏览器只能通过建立多个连接来解决。此外在 HTTP 中对请求是严格的先入先出(FIFO)进行的,如果中间某个请求处理时间较长会阻塞后面的请求(head of line blocking)。虽然HTTP pipelining对连接请求做了改善,但是复杂度太大,并没有普及

2)只允许客户端主动发起请求

3)头冗余
HTTP 头在同一个会话里是反复发送的,中间的冗余信息,比如 User-Agent、Host 等不需要重复发送的信息也在反复发送,浪费带宽和资源

3.HTTP2.0主要改动

1)二进制格式
HTTP1.x是明文协议,由三部分组成:start line、header、body。要识别这3部分需要做协议解析。HTTP1.x的解析是基于文本的,文本的表现形式多样,要做到健壮性考虑场景需很多
HTTP2.0实际上只是把原来HTTP1.x的header和body部分用frame重新封装,并没有改变其语义

2)多路复用
一个request对应一个stream并分配一个id,这样一个连接上可以有多个stream,每个steam的frame可以随机的混杂在一起,接收方根据stream id将frame再归属到各自不同的request里面

3)header压缩
header由于cookie、user agent、host等信息容易膨胀,而且每次要重复发送。HTTP2.0使用encoder来减少header大小

4)重置连接表现变好
HTTP1.x是通过tcp segment里的reset flag来通知对端关闭连接的。这种方式会直接断开连接,下次再发请求就必须重新建立连接。HTTP2.0引入RST_STREAM类型的frame,可以在不断开连接的前提下取消对某个request的stream

5)Server Push
HTTP2.0能通过push的方式将客户端需要的内容预先推送过去(cache push)

6)更安全的SSL

4.HTTP2.0的不足

HTTP2.0对SSL的依赖使得有些开发者望而生畏

6.iOS的HTTP现状

1)iOS系统从iOS8开始通过NSURLSession来支持SPDY
2)iOS9+自动支持HTTP2.0,iOS9+的SDK里NSURLSession默认使用HTTP2.0
3)APN在iOS9上使用HTTP2.0实现

对于开发者而言,主要从2个方面考虑HTTP的使用方案

  • 1.app本身HTTP流量是否大而密集,。在这种场景下,HTTP2.0的才能更好的展示它的优势
  • 2.开发团队本身的技术条件(是选择基于iOS9+适配HTTP2.0,还是基于iOS6+适配SPDY)

参考资料:《iOS成长之路》--- 第二章(MrPeak)

你可能感兴趣的:(HTTP2.0)