AsyncHttpClient使用

 

github地址:AsyncHttpClient

API:API

1.X和2.X差别很大,我用的1.X中的最新版 1.9.39。

这是一个异步请求的工具,越简单越好,不喜欢再结合netty使用。AsyncHttpClient底层使用java线程池

this.applicationThreadPool = Executors.newCachedThreadPool(new ThreadFactory() {
public Thread newThread(Runnable r) {
Thread t = new Thread(r, "AsyncHttpClient-Callback");
t.setDaemon(true);
return t;
}
});

这样的线程池最大线程数没有限制(Integer.MAX_VALUE),就知道开开开线程,在某种情况下会很容易搞垮我们的系统,所以在下面的单例类中做了限制

configBuilder.setMaxConnections(2);

限制提交的数量。可以看出线程池中的线程是daemon的,当所有非daemon线程退出后jvm将退出!!!

 

 

写了个单例类,供参考

import com.ning.http.client.*;

import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Future;

/**
 * Created by yhzh on 2016/9/19.
 */
public class MlsAsyncHttpClient {
    private AsyncHttpClient client;

    private static class HttpClientHolder{
        private static MlsAsyncHttpClient httpClient=new MlsAsyncHttpClient();
    }

    private MlsAsyncHttpClient(){
        AsyncHttpClientConfig.Builder configBuilder=new AsyncHttpClientConfig.Builder();
        configBuilder.setMaxConnections(2);
        /*使用默认值:
        configBuilder.setConnectTimeout(3000);
        configBuilder.setReadTimeout(5000);*/
        configBuilder.setRequestTimeout(60000);
        this.client=new AsyncHttpClient(configBuilder.build());
    }

    public static MlsAsyncHttpClient getAsyncHttpClient(){
        return HttpClientHolder.httpClient;
    }

    public Future<Response> get(String url) {
        return this.client.prepareGet(url).execute();
    }

    public void get(String url, AsyncHandler resHandler) {
        this.client.prepareGet(url).execute(resHandler);
    }

    public Future<Response> post(String url) {
        return this.client.preparePost(url).execute();
    }

    public void post(String url,AsyncHandler resHandler) {
        this.client.preparePost(url).execute(resHandler);
    }

    private Request buildRequest(String url, Map<String,String> paramsMap){
        RequestBuilder requestBuilder = new RequestBuilder();
        if(paramsMap != null && paramsMap.size() > 0) {
            Set<Map.Entry<String, String>> entrySet = paramsMap.entrySet();
            Iterator<Map.Entry<String, String>> iterator = entrySet.iterator();
            while(iterator.hasNext()) {
                Map.Entry<String, String> entry = iterator.next();
                if(entry.getKey() != null) {
                    requestBuilder.addFormParam(entry.getKey(), entry.getValue());
                }
            }
        }
        // 添加RequestHeader,key
        requestBuilder.addHeader("Content-type", "application/x-www-form-urlencoded; charset=UTF-8");
        requestBuilder.setMethod("POST");
        requestBuilder.setUrl(url);

        return requestBuilder.build();
    }

    public Future<Response> post(String url, Map<String,String> paramsMap) {
        Request req=this.buildRequest(url,paramsMap);

        return this.client.executeRequest(req);
    }

    public void post(String url, Map<String,String> paramsMap, AsyncHandler resHandler) {
        Request req=this.buildRequest(url,paramsMap);

        this.client.executeRequest(req,resHandler);
        //this.client.preparePost(url).execute(responseHandler);
    }
}

 

测试代码

@Test
    public void testSelectLoanResultOfLoanResultsOfZgController() throws InterruptedException {
        CountDownLatch completionLatch = new CountDownLatch(2);
        //com.ning.http.client.providers.netty.NettyAsyncHttpProvider
        MlsAsyncHttpClient.getAsyncHttpClient().get("http://127.0.0.1:8081/assetmgmt/ploanouter/repayplan?lrid=0",new AsyncHandler() {
            private ByteArrayOutputStream bytes = new ByteArrayOutputStream();
            boolean done=false;
            @Override
            public STATE onStatusReceived(HttpResponseStatus status) throws Exception {
                int statusCode = status.getStatusCode();
                if (statusCode >= 500) {
                    return STATE.ABORT;
                }
                return STATE.CONTINUE;
            }

            @Override
            public STATE onHeadersReceived(HttpResponseHeaders httpResponseHeaders) throws Exception {
                FluentCaseInsensitiveStringsMap str=httpResponseHeaders.getHeaders();
                return STATE.CONTINUE;
            }

            @Override
            public STATE onBodyPartReceived(HttpResponseBodyPart httpResponseBodyPart) throws Exception {
                bytes.write(httpResponseBodyPart.getBodyPartBytes());
                return STATE.CONTINUE;
            }

            @Override
            public Object onCompleted() throws Exception {
                String str=bytes.toString("utf-8");
                System.out.println("get baidu:");
                completionLatch.countDown();
                return null;
            }

            @Override
            public void onThrowable(Throwable t){
                if(!done){
                    completionLatch.countDown();
                    done=true;
                }
                System.out.println("get exception:"+t.getMessage());
            }
        });

        Map<String,String> m=new HashMap<String,String>();
        m.put("lrid","-1");
        MlsAsyncHttpClient.getAsyncHttpClient().post("http://127.0.0.1:8080/assetmgmt/ploanouter/repayplan",m,new AsyncCompletionHandler() {
            boolean done=false;
            @Override
            public Object onCompleted(Response response) throws Exception {
                String str=response.getResponseBody();
                String name=Thread.currentThread().getName();
                boolean daemon=Thread.currentThread().isDaemon();
                System.out.println("post baidu:");
                completionLatch.countDown();
                return null;
            }

            @Override
            public void onThrowable(Throwable t){
                if(!done){
                    completionLatch.countDown();
                    done=true;
                }
                System.out.println("post exception:"+t.getMessage());
            }
        });

        completionLatch.await();
        System.out.println("异步请求结束!!!");
    }

正如一开始所说(当所有非daemon线程退出后jvm将退出),所以我加了个CountDownLatch,在每个请求可以结束的地方

completionLatch.countDown();

最后

completionLatch.await();

完成退出。

其实如果允许请求无限等待,这样还是有可能导致程序阻塞在await这,可以使用

await(long timeout, TimeUnit unit)

设置时间等待,这个时候请求的响应可能会丢失(参数设置等问题),所以我设置了等待响应的时间

configBuilder.setRequestTimeout(60000);

什么东西还是明确的好,各种参数都要经过调试才能确定

 

 

 

参考文章:

1. java之httpClient 3.x、AsyncHttpClient1.9.x使用总结

2. Async Http Client:异步HTTP和WebSocket客户端

 

转载于:https://www.cnblogs.com/yhzh/p/5889681.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java AsyncHttpClient 是一个基于非阻塞的、事件驱动的 HTTP 客户端库。它提供了简洁易用的 API,用于发送 HTTP 请求并处理响应。AsyncHttpClient 支持异步执行请求,并且可以处理大量的并发请求。它是基于 Netty 库实现的,具有高性能和可靠性。 使用 AsyncHttpClient,你可以创建一个客户端实例并发送各种类型的 HTTP 请求,例如 GET、POST、PUT、DELETE 等。你可以设置请求的 URL、请求头、请求体等,并指定回调函数来处理响应结果。 下面是一个使用 AsyncHttpClient 发送 GET 请求的示例代码: ```java import org.asynchttpclient.*; public class AsyncHttpClientExample { public static void main(String[] args) throws Exception { try (AsyncHttpClient asyncHttpClient = Dsl.asyncHttpClient()) { asyncHttpClient.prepareGet("http://example.com/") .execute(new AsyncCompletionHandler<Response>() { @Override public Response onCompleted(Response response) throws Exception { System.out.println(response.getResponseBody()); return response; } @Override public void onThrowable(Throwable t) { t.printStackTrace(); } }); } } } ``` 在上面的示例中,我们使用 `prepareGet` 方法创建一个 GET 请求,并指定了请求的 URL。然后,我们通过 `execute` 方法发送请求,并使用匿名内部类实现了 `AsyncCompletionHandler` 接口来处理响应结果。在 `onCompleted` 方法中,我们可以获取响应的内容并进行处理。 除了 GET 请求AsyncHttpClient 还支持其他类型的请求,如 POST、PUT、DELETE 等。你可以根据实际需求选择合适的方法进行使用。 希望对你有帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值