杨教授工作室精心创作的优秀程序员职业提升必读系列资料
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性能测试的基础。
DiyVM 香港沙田机房,也是采用的CN2优化线路,目前也有入手且在使用中,我个人感觉如果中文业务需要用到的话虽然日本机房也是CN2,但是线路的稳定性不如香港机房,所以我们在这篇文章中亲测看看香港机房,然后对比之前看到的日本机房。香港机房的配置信息。CPU内存 硬盘带宽IP价格购买地址2核2G50G2M1¥50/月选择方案4核4G60G3M1¥100/月选择方案4核8G70G3M4¥200/月选择...
港云网络官方网站商家简介港云网络成立于2016年,拥有IDC/ISP/云计算资质,是正规的IDC公司,我们采用优质硬件和网络,为客户提供高速、稳定的云计算服务。公司拥有一流的技术团队,提供7*24小时1对1售后服务,让您无后顾之忧。我们目前提供高防空间、云服务器、物理服务器,高防IP等众多产品,为您提供轻松上云、安全防护。点击进入港云网络官方网站港云网络中秋福利1元领【每人限量1台】,售完下架,活...
npidc全称No Problem Network Co.,Limited(冇問題(香港)科技有限公司,今年4月注册的)正在搞云服务器和独立服务器促销,数据中心有香港、美国、韩国,走CN2+BGP线路无视高峰堵塞,而且不限制流量,支持自定义内存、CPU、硬盘、带宽等,采用金盾+天机+傲盾防御系统拦截CC攻击,非常适合建站等用途。活动链接:https://www.npidc.com/act.html...