概述
闲来无事,将以前自己写的一个库放出来吧。。
有的时候会有这样子的需求:
(1)服务器A通过HTTP协议来访问服务器B
(2)服务器A可能会并发的像B发送很多HTTP请求
类似于上述的需求,可能并不常见。。。因为在业务中确实遇到了这样子的场景,所以就自己动手开发了一个库。。。
实现原理:
(1)底层IO通过netty搞
(2)维护一个tcp的长连接池,这样子就不用每次发送请求还要建立一个tcp连接了。。。
下面直接来看怎么用吧:
(1)最常规的用法,向www.baidu.com发送100次get请求:
ClientPool pool = new NettyClientPool(2, "www.baidu.com");
pool.start();
for (int i = 0; i < 100; i++) {
Request re = new Request("/", Request.RequestMethod.GET);
pool.request(re).addListener(new Future.Listener() {
@Override
public void complete(Object arg) {
Response res = (Response)arg;
System.out.println(res.getBody().toString(Charset.forName("utf-8")));
}
@Override
public void exception(Throwable t) {
}
});
}
这里可以看到,其实这里是异步的提交的,所以需要注册一些回调。。。
(2)使用同步的方式发送请求,这里就弄成Post请求吧:
ClientPool pool = new NettyClientPool(2, "www.baidu.com");
pool.start();
Request re = new Request("/", Request.RequestMethod.POST);
re.getBody().writeBytes("aaaa".getBytes(Charset.forName("utf-8")));
try {
Response response = pool.requestWithTimeOut(re, 2000).sync();
System.out.println(response.getBody().toString(Charset.forName("utf-8")));
} catch (Throwable throwable) {
System.out.println(throwable);
}
pool.stop();
这里可以看到,提交请求的时候还带有超时的额,也就是2000毫秒都还没有搞完,那么就不搞了。。
好了,就介绍这些吧,反正post和get请求都有,支持超时控制。。。
支持并发。。。至于说性能嘛。。。应该不差吧,也不知道该跟谁比较。。。。
、
最后给出github地址吧:
https://github.com/2225377fjs/HttpClientPool
点击打开链接
最后
以上就是可爱鱼为你收集整理的支持并发的http客户端(基于tcp连接池以及netty)的全部内容,希望文章能够帮你解决支持并发的http客户端(基于tcp连接池以及netty)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复