杨教授工作室精心创作的优秀程序员职业提升必读系列资料
1. 1 多线程模式下使用HttpClient4组件
1. 1. 1 ThreadSafeClientConnManager类
1、对于同一个HttpConnection同一个时间只能有一个线程访问
由于连接是一种有限的资源每个连接在某一时刻只能供一个线程和方法使用所以需要确保在需要时正确地分配连接。HttpC lient采用了一种类似jdbc连接池的方法来管理连接这个管理工作由MultiThreadedHttpConnec tio nManager完成。
为了保证多线程工作环境下不产生冲突 httpc lie nt使用了一个多线程连接管理器的类ThreadS a feC lientCo nnManager。
2、 ThreadS a feC lie ntC o nnManager类
ThreadSafeClientConnManager类支持下面的两个默认设置项目
ConnManagerPNames.MAX_CONNECTIONS_PER_ROUTE每个主机的最大并行链接数默认为2
ConnManagerPNames.MAX_TOTAL_CONNECTIONS客户端总并行链接最大数默认为20
3、 SchemeRegistry类
4、添加一个线程类
1类名称为MultiGetThread包名称为co m.p x1987.httpc lient并且继承j ava.lang.Thread
杨教授工作室版权所有盗版必究 1/7页
杨教授工作室精心创作的优秀程序员职业提升必读系列资料类
2编程该类的代码package com.px1987.httpclient;import java. io. IOException;import org.apache.http.HttpEntity;import org.apache.http.HttpResponse;import org.apache.http.client.HttpClient;import org.apache.http.client.methods.HttpGet;import org.apache.http.protocol.BasicHttpContext;import org.apache.http.protocol.HttpContext;import org.apache.http.util.EntityUtils;public class MultiGetThread extends Thread {
杨教授工作室精心创作的优秀程序员职业提升必读系列资料private final HttpClient httpClient;private final HttpContext context;private final HttpGet httpGetMethod;private final int threadNo;public MultiGetThread(HttpClient httpClient, HttpGet httpGetMethod, intthreadNo) {this.httpClient = httpClient;this.context = new BasicHttpContext() ;this.httpGetMethod = httpGetMethod;this. threadNo = threadNo;
}
@Overridepublic void run() {
System.out.println(threadNo + " 号 线 程 将要 访 问 " +httpGetMethod.getURI() ) ;try {
HttpResponse response = httpClient.execute(httpGetMethod, context) ;
HttpEntity entity = response.getEntity() ;if (entity != null) {byte[] bytes = EntityUtils. toByteArray(entity) ;
System.out.println(threadNo + "号线程获得长度为" + bytes. length + "字节数据。 ") ;
}
} catch (IOException exception) {
System.out.println(threadNo+"号线程执行过程中出现了下面的错误 "+exception) ;
}finally{httpGetMethod.abort() ;
}
杨教授工作室版权所有盗版必究 3/7页
杨教授工作室精心创作的优秀程序员职业提升必读系列资料}
}
注意需要对每一个HttpClient.execute()的调用必须要有一个abort()与之匹配。
5、多线程模式下使用HttpC lient的代码示例——HttpC lientMultiThreadedDemo
1在项目中添加HttpClientMultiThreadedDemo类
2代码示例package com.px1987.httpclient;import org.apache.http.HttpVersion;import org.apache.http.client.HttpClient;import org.apache.http.client.methods.HttpGet;import org.apache.http.conn.ClientConnectionManager;import org.apache.http.conn.params.ConnManagerParams;import org.apache.http.conn. scheme.PlainSocketFactory;
杨教授工作室精心创作的优秀程序员职业提升必读系列资料import org.apache.http.conn. scheme.Scheme;import org.apache.http.conn. scheme.SchemeRegistry;import org.apache.http.conn. ssl.SSLSocketFactory;import org.apache.http. impl.client.DefaultHttpClient;import org.apache.http. impl.conn. tsccm.ThreadSafeClientConnManager;import org.apache.http.params.BasicHttpParams;import org.apache.http.params.HttpParams;import org.apache.http.params.HttpProtocolParams;public class HttpClientMultiThreadedDemo {
HttpClient httpClient=null;public HttpClientMultiThreadedDemo() {
HttpParams params = new BasicHttpParams() ;
ConnManagerParams. setMaxTotalConnections(params, 100) ;
HttpProtocolParams. setVersion(params, HttpVersion.HTTP_1_1) ;
SchemeRegistry schemeRegistry = new SchemeRegistry() ;schemeRegistry.register(new Scheme("http",
PlainSocketFactory.getSocketFactory() , 8080) ) ;schemeRegistry.register(new Scheme("https",
SSLSocketFactory.getSocketFactory() , 8443) ) ;
ClientConnectionManager cm = new ThreadSafeClientConnManager(params,schemeRegistry) ;httpClient = new DefaultHttpClient(cm, params) ;
String targetURIToGet = "http://127. 0.0. 1:8080/webbank/index. jsp";MultiGetThread[] threads = new MultiGetThread[10] ;for (int i = 0; i < threads. length; i++) {
HttpGet httpGetMethod = new HttpGet(targetURIToGet) ;threads[i] = new MultiGetThread(httpClient, httpGetMethod, i + 1) ;threads[i] . start() ;
}
/*
杨教授工作室版权所有盗版必究 5/7页
杨教授工作室精心创作的优秀程序员职业提升必读系列资料
*不能再此释放连接 因为在线程中海需要应用 httpClient对象本示例为异
步请求
*/
// httpClient.getConnectionManager() . shutdown() ;
}protected void finalize() {httpCl ient.getConnectionManager() . shutdown() ; //释放连接
}public static void main(String[] args) throws Exception {
HttpClientMultiThreadedDemo httpClientMultiThreadedDemo=newHttpClientMultiThreadedDemo() ;
}
}
在客户端的代码中同时产生出10个线程 向同一个URL地址发送请求。注意释放httpClient对象的方式否则会出现下面的错误。
6、示例代码执行的结果
杨教授工作室版权所有盗版必究 6/7页
杨教授工作室精心创作的优秀程序员职业提升必读系列资料
该示例其实是Web性能测试的基础。
无忧云怎么样?无忧云,无忧云是一家成立于2017年的老牌商家旗下的服务器销售品牌,现由深圳市云上无忧网络科技有限公司运营,是正规持证IDC/ISP/IRCS商家,主要销售国内、中国香港、国外服务器产品,线路有腾讯云国外线路、自营香港CN2线路等,都是中国大陆直连线路,非常适合免备案建站业务需求和各种负载较高的项目,同时国内服务器也有多个BGP以及高防节点。一、无忧云官网点击此处进入无忧云官方网站二...
Virmach自上次推出了短租30天的VPS后,也就是月抛型vps,到期不能续费,直接终止服务。此次又推出为期6个月的月抛VPS,可选圣何塞和水牛城机房,适合短期有需求的用户,有兴趣的可以关注一下。VirMach是一家创办于2014年的美国商家,支持支付宝、PayPal等方式,是一家主营廉价便宜VPS服务器的品牌,隶属于Virtual Machine Solutions LLC旗下!在廉价便宜美国...
GigsGigsCloud新上了洛杉矶机房国际版线路VPS,基于KVM架构,采用SSD硬盘,年付最低26美元起。这是一家成立于2015年的马来西亚主机商,提供VPS主机和独立服务器租用,数据中心包括美国洛杉矶、中国香港、新加坡、马来西亚和日本等。商家VPS主机基于KVM架构,所选均为国内直连或者优化线路,比如洛杉矶机房有CN2 GIA、AS9929或者高防线路等。下面列出这款年付VPS主机配置信息...