杨教授工作室精心创作的优秀程序员职业提升必读系列资料
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性能测试的基础。
金山云618年中促销活动正在进行中!金山云针对企业级新用户优惠力度比普通个人用户优惠力度要大,所以我们也是推荐企业新用户身份购买金山云企业级云服务器,尽量购买3年配置的,而不是限时秒杀活动中1年的机型。企业级用户购买金山云服务器推荐企业专区:云服务器N3 2核4G云服务器,1-5M带宽,827.64元/3年,性价比高,性能稳定!点击进入:金山云618年中促销活动目前,金山云基础型E1云服务器2核4...
mineserver怎么样?mineserver是一家国人商家,主要提供香港CN2 KVM VPS、香港CMI KVM VPS、日本CN2 KVM VPS、洛杉矶cn2 gia端口转发等服务,之前介绍过几次,最近比较活跃。这家新推出了洛杉矶CN2 GIA VPS,512MB内存/20GB NVME/800GB流量/200Mbps/KVM,58元/季,并且进行了带宽升级,同时IP更改为美国IP。点击...
触摸云触摸云(cmzi.com),国人商家,有IDC/ISP正规资质,主营香港线路VPS、物理机等产品。本次为大家带上的是美国高防2区的套餐。去程普通线路,回程cn2 gia,均衡防御速度与防御,防御值为200G,无视UDP攻击,可选择性是否开启CC防御策略,超过峰值黑洞1-2小时。最低套餐20M起,多数套餐为50M,适合有防御型建站需求使用。美国高防2区 弹性云[大宽带]· 配置:1-16核· ...