2.1 连接管理器HttpClientConnectionManager
首先介绍路由(HttpRoute)的概念,我们可以理解成一条连接的路线。如果多个线程访问的是同一个IP+端口,我们就认为他们实际上使用的是同一个HttpRoute。
HTTP连接不是一个线程安全的对象,因此一个HTTP连接一次只能由一个线程使用。HttpClient使用HttpClientConnectionManager接口来管理Http连接,它管理Http连接的生命周期和线程安全,保证一个连接至多有一个线程访问。
2.1.1* BasicHttpClientConnectionManager
一次只维护一个连接,因此它只能被一个线程使用。如果持久连接的路由与连接请求的路由不匹配,则会关闭现有连接并重新打开给定路由。如果连接已经被分配,则抛出java.lang.IllegalStateException。
可以理解成MaxTotal=1,DefaultMaxPerRoute=1的PoolingHttpClientConnectionManager。
2.1.2 PoolingHttpClientConnectionManager
通过名字就可以知道这是一个Http连接池。它将连接按照路由进行合并,如果一个请求的路由在池中存在并且有空闲的连接,就复用连接池中的连接而不是创建新的连接。
连接池有两个重要的参数,那就是连接池中连接上限MaxTotal和每一个路由的连接上限DefaultMaxPerRoute。默认参数的MaxTotal=20,DefaultMaxPerRoute=2。这个一般都不能够满足我们生产环境的需要,因此在使用连接池时有必要根据需要自己设置这两个参数。
PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager();
// Increase max total connection to 200
cm.setMaxTotal(200);
// Increase default max connection per route to 20
cm.setDefaultMaxPerRoute(20);
// Increase max connections for localhost:80 to 50
HttpHost localhost = new HttpHost("lo