OkHttp完全解析(四)连接Connections

尽管程序只提供了URL,但是OkHttp在连接web服务器时会使用三种类型:URL, 地址Addresses,路线Route。
[源码分析:4.2] 连接引擎HttpEngine

5.1URL
URLs是抽象的
* 它们指定了调用是明文的http还是加密的https,而不是那个加密规则系统被使用。它们也没有指定如何验证数字证书,或者应该能够信任哪个数字证书。
* 它们没有指定是否特定的代理服务器会被使用或者如何证明一个代理服务器。
URLs也是固定的,每个URLs表明一个特定的地址,和查询,每个web服务器持有许多个URL。
5.2Address
地址指定了一个web服务器,所有的静态配置需要连接到服务器:端口号,https设置,优先级网络协议(像 HTTP/2 或者 SPDY)
【OkHttp完全解析(四)连接Connections】共享相同地址的URL也可能共享相同的潜在TCP socket连接。 共享一个连接有巨大的性能优势:低延时,高生产力(因为TCP启动缓慢),省电。OKHttp使用一个可以自动重用chongyo9ngHTTP/1.x 连接,多路传输的HTTP/2连接,SPDY连接的连接池。
在OkHttp中,地址的有些属性来自URL,剩下的来自OkHttpClient。
5.3Route
路线提供实际连接到web服务器的动态信息。包括连接的IP地址,具体使用的代理服务器,以及协商的TLS版本。
对于一个地址而言,可能有很多的线路,例如,一个托管在多个数据中心的web服务器在其DNS相应中可能产生多个IP地址。
5.4Connections
当你通过OkHttp请求一个URL时,会发生下面的事情:
1.通过URL和配置的OkHttpClient创建一个地址。这个地址指定如何连接到web服务器。
2.试图根据这个地址从连接中恢复一个连接。
3.如果没有在连接池中找到连接,则选择一条线路连接。这就意味着创建一个DNS请求,获取服务器的IP地址。 然后根据需要,选择一个TLS版本,和代理服务器。
4.如果这是一条新的线路,则通过创建一个直接的socket连接,一个TLS隧道(对于HTTPS而言是一个HTTP代理),或者创建一个直接的TLS连接。然后进行TLS握手。
5.发送请求,获取响应。如果连接出问题,OkHttp会选择另外一条路线重试。这就允许OkHttp在服务器地址的子集不可达时进行恢复。 在连接池中的连接陈旧或者尝试的TLS版本不支持时,这一功能也是非常有用的。
注:TLS: 安全传输层协议(TLS)用于在两个通信应用程序之间提供保密性和数据完整性。该协议由两层组成: TLS 记录协议(TLS Record)和 TLS 握手协议(TLS Handshake)。

    推荐阅读