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)