iOS猛码计划iOS精品文章-面试ios 知识小集

关于 iOS HTTP2.0 的一次学习实践

2017-04-21  本文已影响5222人  Joy___

前面的文章也提到了目前的移动端网络常见性能问题,以及对应的优化策略,如果把HTTP1.1 替换为 HTTP2.0,可以说是网络性能优化的一步大棋。这几天对 iOS HTTP2.0 进行了简单的调研、测试,在此做个简单的总结

本文的大概思路是介绍 HTTP1.1 的弊端、HTTP2.0 的优势、HTTP2.0 的协商机制、iOS 客户端如何接入 HTTP2.0,以及如何对其进行调试。主要还是加深记忆、方便后期查阅,文末的资料相比本文或许是更有价值的。

HTTP 1.1

HTTP2.0

在 HTTP2.0中,上面的问题几乎都不存在了。HTTP2.0 的设计来源于 Google 的 SPDY 协议,如果对 SPDY 协议不了解的话,也可以先对 SPDY 进行了解,不过这不影响继续阅读本文

流(Stream):一个Stream是包含一条或多条信息、ID和优先级的双向通道

消息(Message):消息由帧组成

帧(Frame):帧有不同的类型,并且是混合的。他们通过stream id被重新组装进消息中

除了上面讲到的特性,HTTP2.0 还有流量控制、流优先级和依赖性等功能。更多细节可以参考:Hypertext Transfer Protocol Version 2 (HTTP/2)

iOS 客户端接入HTTP 2.0

iOS 如何接入 HTTP 2.0呢?其实很简单:

HTTP 2.0的协商机制

上面说了一堆名次,什么NPN、ALPN呀,还有h2、h2c之类的,有点懵逼。NPN(Next Protocol Negotiation)是一个 TLS 扩展,由 Google 在开发 SPDY 协议时提出。随着 SPDY 被 HTTP/2 取代,NPN 也被修订为 ALPN(Application Layer Protocol Negotiation,应用层协议协商)。二者目标一致,但实现细节不一样,相互不兼容。以下是它们主要差别:

同时,目前很多地方开始停止对NPN的支持,仅支持 ALPN,所以公司使用的话,最佳是直接使用 ALPN。

下面就直接来看看 ALPN 的协商过程是怎样的,ALPN 作为 TLS 的一个扩展,其过程可以通过 WireShark 查看 TLS握手过程来查看

下面通过 WireShark 来进行调试,接入真机,然后终端输入
rvictl -s 设备 UDID来创建一个映射到 iPhone 的虚拟网卡,UUID 可以在 iTunes 中获取到,运行命令后会看到成功创建 rvi0 虚拟网卡的,双击 rvi0 开始调试。

进入之后,在手机上访问页面会有源源不断的请求显示在 WireShark 的界面上,数据太多而不利于我们针对性调试,你可以过滤下域名,只关注你想测试的 ip 地址,比如: ip.addr==111.89.211.191 ,当然你的 ip 要支持 HTTP2.0才会有预想的效果哦

下面,就开始通过查看 TLS 握手的过程分析HTTP2.0 的协商过程,刚才也说道 ALPN 协商结果是在 Client hello 和 Server hello 中显示的,那就先来看一下Client hello

可以看到客户端在 Client hello 中列出了自己支持的各种应用层协议,比如 spdy3、h2。那么接着看 Server hello 是如何回复的

服务端会根据 client hello 中的协议列表,发过去自己支持的网络协议,假如服务端支持 h2,则直接返回h2,协商成功,如果不支持 h2,则返回一个其他支持的协议,比如HTTP1.1、spdy3

这个是h2的协商过程,对于刚才提到的 h2c 的协商过程,与此不同,h2c 利用的是HTTP Upgrade 机制,客户端会发送一个 http 1.1的请求到服务端,这个请求中包含了 http2的升级字段,例如:

  GET /default.htm HTTP/1.1
  Host: server.example.com
  Connection: Upgrade, HTTP2-Settings
  Upgrade: h2c
  HTTP2-Settings: <base64url encoding of HTTP/2 SETTINGS payload>

服务端收到这个请求后,如果支持 Upgrade 中 列举的协议,这里是 h2c,就会返回支持的响应:

  HTTP/1.1 101 Switching Protocols
  Connection: Upgrade
  Upgrade: h2c

  [ HTTP/2 connection ...

当然,不支持的话,服务器会返回一个不包含 Upgrade 的报头字段的响应。

我的客户端支持了吗?

一切准备就绪之后,也是时候对结果进行验证了,除了刚才提到的 WireShark 之外,你还可以使用下面的几个工具来对 HTTP 2.0 进行测试

点击小闪电,会进入一个页面,列举了当前浏览器访问的全部 http2.0的请求,所以,你可以把你想要测试的客户端接口在浏览器访问,然后在这个页面验证下是否支持 http2.0

大礼包

上一篇 下一篇

猜你喜欢

热点阅读