SAKA'S BLOG

OKHttp(二)之Connections

网址(URLS)

URL(如https://github.com/square/okhttp)是HTTP和Internet的基础。 除了是一个通用的,他们还指定通过什么方法来访问网络资源。

URL是抽象的:

  • 它们指定调用可以是明文(http)或加密(https),但不能指定使用哪种加密算法。 它们也不指定如何验证证书(HostnameVerifier)或哪些证书可以信任(SSLSocketFactory)。
  • 它们不指定是否应使用特定的代理服务器或如何使用该代理服务器进行身份验证。

它们也是具体的:每个URL标识一个特定的路径(如/ square / okhttp)和参数(如?q = sharks&lang = en)。 每个Web服务器都托管许多URL。

地址

地址指定一个网络服务器(如github.com)以及连接到该服务器所需的所有静态配置:端口号,HTTPS设置和首选网络协议(如HTTP / 2或SPDY)。

共享相同地址的URL也可以共享相同的底层TCP套接字连接。 共享连接具有显着的性能优势:更低的延迟,更高的吞吐量(由于TCP慢启动)和节省电量。 OkHttp使用一个ConnectionPool,它自动重用HTTP / 1.x连接并复用HTTP / 2和SPDY连接。

在OkHttp中,地址的一些字段来自URL(方案,主机名,端口),其余的来自OkHttpClient。

路由

路由提供了连接到服务器所需的动态信息。包括要尝试的特定IP地址(由DNS参数查询发现),要使用的确切代理服务器(如果使用ProxySelector)和要协商的TLS(HTTPS连接)的版本。

单个地址可能有许多路由。 例如,托管在多个数据中心中的web服务器可以在其DNS响应中产生多个IP地址。

连接

当你使用OkHttp携带URl发起请求时,会做以下工作:

  • 使用URl和配置好的OkHttpClient创建一个地址,这个地址指定如何连接到服务器。
  • 尝试从连接池中检索与该地址的连接
  • 如果在池中找不到连接,它会选择路由。 这通常意味着使DNS请求获取服务器的IP地址。 然后根据需要选择TLS版本和代理服务器。
  • 如果它是一个新路由,它通过构建直接套接字连接,TLS隧道(通过HTTP代理的HTTPS)或直接TLS连接进行连接。 它根据需要进行TLS握手。
  • 发送HTTP请求并读取响应。

如果连接发生错误,OkHttp会选择其他路由或者重试。这允许OkHttp在服务器的地址子集不可达时恢复。当连接失效或尝试的TLS版本不受支持时,它也很有用。

一旦接受到响应,连接将会返回连接池中来为以后的请求服务。当一段时间不运行后,连接将会取消。