关于SpringBoot MVC接口超时时间的分析

embedded/2024/10/19 2:20:49/

前言

如果在网上搜索,SpringBoot接口超时时间,很多人会说是配置:spring.mvc.async.request-timeout,这个回答对也不对。主要是这个问题问的就不清不楚,所以这个答案也就不清不楚了。

结论

同步接口没有超时时间一说;

spring.mvc.async.request-timeout配置的是异步接口的超时时间:这里的超时指的是:从主请求处理线程退出后开始,到再次调度请求以进一步处理并发生成的结果时结束。

接口超时时间?

接口超时时间——这句话要分为两部分来分析,第一:什么接口?第二:超时时间是指的什么时间?

首先来看第一个,什么接口?在servlet3.0之后,有同步和异步之分,所以这里的接口没有说明是同步接口还是异步接口。不过一般来说,大多数人用的都是同步接口。

而第二个,超时时间:姑且认为,是我的业务代码执行的时间。

因此,现在来看这个问题:如果说,是一个异步接口,那么spring.mvc.async.request-timeout的配置值是有效的。并且这个指定的是异步请求处理超时之前的时间量(以毫秒为单位)。在 Servlet 3 中,超时从主请求处理线程退出后开始,到再次调度请求以进一步处理并发生成的结果时结束。 请看以下代码:

@GetMapping("/testCallAble")
public Callable<String> testCallAble() throws InterruptedException {Thread.sleep(t1);return () -> {Thread.sleep(t2);return "hello";};
}

这是一个异步接口,spring.mvc.async.request-timeout=5S,即异步接口5秒超时,当

  • t1=10000即10s,t2=1000即1s时,接口可正常返回;
  • t1=1000即1s,t2=10000即10s时,接口会报错:AsyncRequestTimeoutException

结合这两个结果,再来理解这配置spring.mvc.async.request-timeout的含义,就清楚了。

但如果不是异步接口,是一个同步的接口呢?这个配置对同步接口不生效,你看配置中的async也知道它说的是异步。其实,对于同步接口来说,没有超时时间一说:即服务端没法对接口进行超时时间配置(其他框架或者个人自行扩展实现的那就另当别论了)。再说的具体一点,A应用调用B应用,那么所谓的超时,都是在客户端配置的,即A应用配置的,而B应用无需设置自己业务代码的超时时间。当然,有时A和B之间可能会有一个网关,网关这里也可以配置超时时间,那么对于A而言,就像是B配置了超时时间,但这个对于B而言,网关也是一个客户端了,所以客户端设置超时时间是可以的。

我个人理解:在同步接口中,一个代码的执行时间是可控的——一个接口与之相关的代码编译的指令有多少,这个可以确定,而唯一不确定的是这个接口调用其他的接口、或者链接数据库之类的,但这个时候,它就变成了客户端,可以设置超时时间了,有了超时时间,那么这些不确定的时间,又变成可确定的了。既然一个可确定时长的代码,又何必再整一个配置来限制它呢?认真想想,就会觉得确实如此。

而异步接口却不一样,它会脱离主线程(tomcat的工作线程),等脱离到再次被执行响应的这个时间是不确定的,所以有必要给一个时间来限制它。认真想想~~~

异步接口超时时间默认值

看文档,这个异步接口超时时间有这么一个说明:如果未设置此值,则使用基础实现的默认超时。这里,这个超时时间默认是30秒(可以从org.apache.catalina.core.AsyncContextImpl中的timeout可以看到),如果配置为0或者-1,则表示永不超时;

另外,这个配置是有优先级的,优先级高的会覆盖低优先级的:

  1. 具体的接口(WebAsyncTask中设置的超时时间)配置的时间,优先级最高;
  2. 其次是WebMvcConfigurer.configureAsyncSupportAsyncSupportConfigurer设置的DefaultTimeout
  3. 其次是配置文件中,配置的spring.mvc.async.request-timeout
  4. 最后才是默认的

server.tomcat.connection-timeout

server.tomcat.connection-timeout配置的作用是:指定了客户端与服务器之间的连接超时时间。当客户端连接到Tomcat服务器时,如果在指定的时间内没有完成与服务器的握手,连接将被视为超时并关闭。注意:是建立连接需要的时间,并非连接处理的时间。


http://www.ppmy.cn/embedded/39734.html

相关文章

Qt之常用控件一

Widget常见属性及其作用 属性作用enabled 设置控件是否可使⽤. true 表⽰可⽤, false 表⽰禁⽤ geometry 位置和尺⼨. 包含 x, y, width, height 四个部分. 其中坐标是以⽗元素为参考进⾏设置的. windowTitle 设置 widget 标题 windowIcon 设置 widget 图标 windowOpa…

从零开始学AI绘画,万字Stable Diffusion终极教程(三)

【第3期】Lora模型 欢迎来到SD的终极教程&#xff0c;这是我们的第三节课 这套课程分为六节课&#xff0c;会系统性的介绍sd的全部功能&#xff0c;让你打下坚实牢靠的基础 1.SD入门 2.关键词 3.Lora模型 4.图生图 5.controlnet 6.知识补充 在SD里面&#xff0c;有一个…

spring alibaba中的seata分布式事务

Seata AT 模式设计思路 一阶段&#xff1a;业务数据和回滚日志记录在同一个本地事务中提交&#xff0c;释放本地锁和连接资源。 核心在于对业务sql进行解决解析&#xff0c;转换成undolog&#xff0c;并同时入库存 二阶段&#xff1a; 提交异步化&#xff0c;非常快速地完成…

漫谈AI时代的手机

以chatGPT 为代表的大语言的横空出世使人们感受到AI 时代的到来&#xff0c;大语言模型技术的最大特点是机器开始”懂人话“&#xff0c;”说人话“了。如同任何一个革命性工具的出现一样&#xff0c;它必将改变人类生活和工作。 在这里。我谈谈AI时代的手机。 语音通信的历史…

rust打包编译为mac或者linux可执行文件,发送到别的电脑不能运行

如果使用rust项目编译为linux或者mac可执行文件&#xff0c;发送到别的电脑之后&#xff0c;不可以直接运行&#xff0c;而是显示一个空白文件&#xff0c;双击也没有反应&#xff0c;其实这是因为这个文件没有可执行权限导致的&#xff0c;添加可执行权限就可以了&#xff1a;…

SSL/TLS 协议

目录 概述 TLS 握手协议&#xff1a;建立安全连接的基础 TLS 握手流程&#xff1a;建立安全通道的关键步骤 TLS 记录协议&#xff1a;确保数据完整性和机密性 验证分析与 TLS 协议&#xff1a;确保服务器身份和数据完整性 TLS 与 SSL 的差异&#xff1a;演变和改进 结论 …

基于单片机的直流电机控制方法研究

摘要&#xff1a;分析表明&#xff0c;我国用电设备应用数量的持续增加&#xff0c;单片机在电力领域的应用范围也在不断扩大。基 于对电动机运行转速的有效控制&#xff0c;成为自动控制系统关注的重点。研究单片机控制直流电机运行状态的 方法。 关键词&#xff1a;单片机&a…

【Linux 命令操作】如何在 Linux 中使用多行注释呢?

文章目录 1. 给代码进行多行注释2. 给代码取消多行注释 1. 给代码进行多行注释 &#x1f427;① 首先用 vim 打开代码&#xff0c;按 Esc进入命令模式(Normal mode)&#xff1b; &#x1f427;② 然后按住 ctrl v 进入列模式&#xff1b; &#x1f427;③ 再通过按 h(左)、j(…