教授通过代码示例学习Commons HTTPClient4组件的编程技术——多线程模式下使用HttpClient4组件

httpclient4  时间:2021-01-29  阅读:()

杨教授工作室精心创作的优秀程序员职业提升必读系列资料

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性能测试的基础。

华纳云新人下单立减40元/香港云服务器月付60元起,香港双向CN2(GIA)

华纳云(HNCloud Limited)是一家专业的全球数据中心基础服务提供商,总部在香港,隶属于香港联合通讯国际有限公司,拥有香港政府颁发的商业登记证明,保证用户的安全性和合规性。 华纳云是APNIC 和 ARIN 会员单位。主要提供数据中心基础服务、互联网业务解决方案, 以及香港服务器租用、香港服务器托管、香港云服务器、美国云服务器,云计算、云安全技术研发等产品和服务。其中云服务器基于成熟的 ...

Fiberia.io:$2.9/月KVM-4GB/50GB/2TB/荷兰机房

Fiberia.io是个新站,跟ViridWeb.com同一家公司的,主要提供基于KVM架构的VPS主机,数据中心在荷兰Dronten。商家的主机价格不算贵,比如4GB内存套餐每月2.9美元起,采用SSD硬盘,1Gbps网络端口,提供IPv4+IPv6,支持PayPal付款,有7天退款承诺,感兴趣的可以试一试,年付有优惠但建议月付为宜。下面列出几款主机配置信息。CPU:1core内存:4GB硬盘:...

GreenCloudVPS($30/年),500G大硬盘VPS,10Gbps带宽

GreenCloudVPS最近在新加坡DC2节点上了新机器,Dual Xeon Silver 4216 CPU,DDR4内存,10Gbps网络端口,推出了几款大硬盘VPS套餐,基于KVM架构,500GB磁盘起年付30美元。除了大硬盘套餐外,还加推了几款采用NVMe硬盘的常规套餐,最低年付20美元。不过需要提醒的是,机房非直连中国,尤其是电信用户ping值感人,包括新加坡DC1也是如此。大硬盘VPS...

httpclient4为你推荐
金士顿内存真假金士顿内存怎么分辨真伪?免费送q币活动有什么活动可以免费获得QB?录屏软件哪个好有什么好用的游戏录屏软件推荐吗?江门旅游景点哪个好玩的地方江门有哪些旅游景点,江门哪里好玩朗逸和速腾哪个好大众速腾与朗逸哪个好石英表和机械表哪个好石英表好还是机械表好?核芯显卡与独立显卡哪个好独立显卡和核芯显卡有什么区别网校哪个好初中网校哪个好?云盘哪个好免费的网盘哪个实用?51空间登录怎样登51个人空间
免费申请域名 免费顶级域名 lnmp 踢楼 樊云 好看的桌面背景图 网通服务器ip e蜗牛 促正网秒杀 hostloc 台湾谷歌 服务器硬件防火墙 www789 英雄联盟台服官网 免费网络空间 国外代理服务器 googlevoice 镇江高防服务器 symantec 招聘瓦工 更多