Http请求系列---【http的几个请求时间分别代表什么?以及如何设置?】

在HTTP客户端编程中,通常涉及以下几种关键的超时设置:

  1. 连接超时 (connectTimeout)

    • 定义:在与服务器建立连接时等待的最大时间。这包括DNS解析时间、连接建立时间等。
    • 作用:如果在指定的时间内无法建立连接,抛出异常(如 SocketTimeoutException)。
    • 用途:用于防止客户端无限期地等待无法建立的连接。合理设置可以防止应用程序在服务器不可用或网络问题时挂起。
  2. 读取超时 (readTimeout)

    • 定义:在从服务器读取数据时等待的最大时间。
    • 作用:如果在指定时间内没有从输入流读取到数据,抛出异常。
    • 用途:适用于防止客户端在读取响应数据时因服务器响应延迟或网络中断而无限期等待。
    • 注意:和socketTimeout大多数情况下是同一个意思,都报:SocketTimeoutException异常。
  3. 写入超时

    • 定义:在向服务器发送数据时等待的最大时间。
    • 注意:虽然Java标准库的 HttpURLConnection 不直接提供写超时设置,但在某些库或网络客户端实现中(如OkHttp、Netty等)存在,一定要注意。
    • 用途:防止客户端在大文件上传或网络不佳的情况下,长时间等待数据发送的完成。

代码示例

以下是使用 Hutool的HttpRequest 设置连接超时和读取超时的示例:

注意:如果渠道端发送了请求,下游没有接收到,请检查一下渠道端发送http的工具是否有writeTimeout参数设置或默认设置,这个影响请求发送,当请求体比较大时,没发完就超时了;或者检查中间件nginx是否设置了proxy_send_timeout 60s;,这个也影响发送时长。

    @GetMapping("channel")
    public String channel(String channel) {
        HashMap<String, Object> hashMap = new HashMap<>();
        hashMap.put("channel", channel);
        HttpRequest.get("http://127.0.0.1:8088/qingqiu/DE001").form(hashMap)
                //和服务器的请求连接时间
                .setConnectionTimeout(1000)
                // 设置readTimeout超时时间为1毫秒,测试超时情况,请求会报错,但是不会影响请求发送,只会影响请求响应的结果,报错信息为Read timed out
                .setReadTimeout(1)
                .execute();
        return "ok";
    }

    @GetMapping("qingqiu/DE001")
    public String sde(String channel) throws InterruptedException {
        Thread.sleep(100);
        System.out.println("引擎接收到请求,channel = " + channel);
        return "响应结果";
    }

其他注意事项

  • 默认设置:一些HTTP客户端可能有默认的超时设置,可以根据应用需求进行调整。
  • 重试机制:在某些网络环境下,结合重试机制可以提高请求的成功率。
  • 库支持:不同的HTTP库(如Apache HttpClient、OkHttp等)可能提供更丰富的超时和重试配置选项,可以根据项目需求选用合适的库。

posted on   少年攻城狮  阅读(200)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2019-12-06 开发中遇到的问题---【feign的多参数问题】
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示