apache HttpClient参数说明

正文

HttpClient组件使用的地方较多,很多HTTP客户端都是封装的HTTPClient(spring restTempalte就是基于HTTPClient构建的);HTTPClient可以设置的参数较多,部分参数的设置堆系统影响较大,需要对各个参数有个透彻的了解。
以下是基于使用PoolingHttpClientConnectionManager

项目说明默认值备注
maxConnTotalHTTPClient能够创建的最大连接数20达到上线后,需要等待其他连接销毁后才能继续创建
该数值设得过小在高并发的场景下会阻塞客户端调用
maxConnPerRouteHTTPClient2相同域名允许创建的最大连接数
该值过小影响与maxConnTotal一样
maxIdleTime连接允许的最大空闲时间10秒如果不设置不会清理空闲连接,可能造成服务端连接数耗尽
defaultRequestConfig#connectTimeout连接超时时间
(tcp三次握手完成时间)
-1(无超时)不设置会导致无限等待,有雪崩的风险
(前端无响应刷新页面,会不断发送业务请求)
defaultRequestConfig#socketTimeout2帧网络包之间的间隔时间
或者说socket调用InputStream读数据的超时时间
-1(无超时)影响同defaultRequestConfig#connectTimeout
defaultRequestConfig#connectionRequestTimeout连接池创建连接时的超时时间-1(无超时maxConnTotal设置过小,导致创建连接时阻塞,
connectionRequestTimeout用于设置这个超时时间
超时后抛出异常(Timeout waiting for connection from pool)

socketTimeout测试及说明

任何网络框架,底层都是基于jdk的Socket。
HTTPClient的socketTimeout参数对应的是Socket的soTimeout,代表读请求的阻塞时间。超过该时间后,抛出异常(java.net.SocketTimeoutException: Read timed out)

   public static void main(String[] args) throws IOException {
        new Thread(() -> {
            try {
                ServerSocket serverSocket = new ServerSocket(8001);
                while (true) {
                    Socket socket = serverSocket.accept();
                    OutputStream outputStream = socket.getOutputStream();
                    for(int i = 0;i<5;i++) {
                        Thread.sleep(1000);
                        outputStream.write('a');
                    }
                    socket.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }).start();
        new Thread(() -> {
            try {
                Socket socket = new Socket("127.0.0.1",8001);
                socket.setSoTimeout(2000);
                InputStream inputStream = socket.getInputStream();
                System.out.println(inputStream.read(new byte[1024]));
            } catch (IOException e) {
                e.printStackTrace();
            }
        }).start();
    }

测试1-SoTimeout>服务端的睡眠时间

日志打印1,表示只读到1个字节。

测试结果说明

read操作并不一次性读取完整的数据,而是当前接收多少就读多少。因为从Socket这一层并不知道服务端要传多少数据,只能读多少算多少。tcp协议只是个传输协议,因此要设计http等应用层协议,才能正确的工作。

测试2-SoTimeout<服务端的睡眠时间

测试结果-抛出异常

java.net.SocketTimeoutException: Read timed out
	at java.net.SocketInputStream.socketRead0(Native Method)
	at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
	at java.net.SocketInputStream.read(SocketInputStream.java:171)
	at java.net.SocketInputStream.read(SocketInputStream.java:141)
	at java.net.SocketInputStream.read(SocketInputStream.java:127)
	at com.example.demo.DemoApplication.lambda$main$1(DemoApplication.java:54)
	at java.lang.Thread.run(Thread.java:748)

测试结果说明

因为SoTimeout<服务端的睡眠时间,客户端在读到有效数据前已经超过设定的SoTimeout,因此抛出异常。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Apache HttpClient是一个开源的Java库,用于进行HTTP通信。它提供了一组易于使用的方法和类,用于创建和执行HTTP请求,并处理与服务器之间的通信。 使用Apache HttpClient,您可以发送HTTP请求(如GET、POST、PUT、DELETE),设置请求头,添加请求参数,处理响应,以及处理重定向和认证等功能。它还支持连接池和连接管理器,以便更高效地处理多个请求。 以下是使用Apache HttpClient发送GET请求的简单示例代码: ```java import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.HttpResponse; import org.apache.http.impl.client.HttpClients; public class HttpClientExample { public static void main(String[] args) throws Exception { HttpClient httpClient = HttpClients.createDefault(); HttpGet request = new HttpGet("https://www.example.com"); HttpResponse response = httpClient.execute(request); int statusCode = response.getStatusLine().getStatusCode(); System.out.println("Status Code: " + statusCode); } } ``` 此示例创建了一个默认的HttpClient实例,并发送了一个GET请求到"https://www.example.com"。然后,它从响应中获取状态码,并将其打印输出。 您可以在项目中引入Apache HttpClient的依赖,以便开始使用它。具体的依赖配置取决于您使用的构建工具(如Maven或Gradle)。 注意:在使用Apache HttpClient进行网络通信时,请确保您遵循适用的法律法规和网站的服务条款,并始终尊重服务器的使用政策。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值