Springboot调整接口响应返回时长详解(解决响应超时问题)

11 篇文章 0 订阅
10 篇文章 0 订阅
文章介绍了在SpringBoot应用中,针对大数据处理或长耗时操作可能导致的超时问题,提供了配置Http会话超时和接口访问超时的解决方案,包括在application.properties中设置和通过编程方式设置。同时,提醒读者注意在Tomcat和Nginx的配置中也要相应调整超时时间,以确保整个服务的稳定运行。
摘要由CSDN通过智能技术生成
一、前言

  当后端对于数据量较大的处理或是某些耗时的操作时,需要先对请求接口的请求进行响应。实际场景中会遇到请求业务处理流程耗时较长,比如长查询,远程调用等,主线程会被一直占用会影响其他请求的响应,导致服务端性能下降。同时,前端向服务端发送请求后等待响应的超时时间比较短(一般20s或30s),而我们实际业务执行可能超过1分钟,甚至可以达到5分钟。

二、解决方案
1、配置Http会话超时

  可以通过两种方式为Spring Boot应用程序配置HTTP会话超时

1.1 application.properties中配置会话超时

  最简单的方法是在你的application.properties中加入参数server.servlet.session.timeout

server:
  servlet:
    session:
      # 配置会话超时
      timeout: 120s

还要注意的是,Tomcat不允许你将超时时间设置得少于60秒

1.2 以程序方式配置会话超时

  假设我们想让我们的HttpSession只持续两分钟。为了实现这一点,我们可以在我们的WebConfiguration类中添加一个EmbeddedServletContainerCustomizerBean,内容如下。

@Configuration
public class WebConfiguration {
  @Bean
  public EmbeddedServletContainerCustomizer embeddedServletContainerCustomizer() {
    return new EmbeddedServletContainerCustomizer() {
      @Override
      public void customize(ConfigurableEmbeddedServletContainer container) {
        container.setSessionTimeout(2, TimeUnit.MINUTES);
      }
    };
  }
}

这里再给出一个使用Java 8和lambda表达式的捷径写法。

public EmbeddedServletContainerCustomizer embeddedServletContainerCustomizer() {
    return (ConfigurableEmbeddedServletContainer container) -> {
      container.setSessionTimeout(2, TimeUnit.MINUTES);
    };
  }

  在应用程序启动期间,Spring Boot自动配置检测到EmbeddedServletContainerCustomizer,并调用customize(…)方法,传递对Servlet容器的引用

2、配置接口访问超时

  SpringBoot设置接口访问超时时间有两种方式

2.1 配置文件方式

  在配置文件application.properties中加了spring.mvc.async.request-timeout=120000,意思是设置超时时间为120000ms即120s

# [设置接口的超时时间]
spring.mvc.async.request-timeout=120000
2.2 配置Config配置类

  还有一种就是在config配置类中加入:

public class WebMvcConfig extends WebMvcConfigurerAdapter {
	@Override
	public void configureAsyncSupport(final AsyncSupportConfigurer configurer) {
		configurer.setDefaultTimeout(20000);
		configurer.registerCallableInterceptors(timeoutInterceptor());
	}

	@Bean
	public TimeoutCallableProcessingInterceptor timeoutInterceptor() {
		return new TimeoutCallableProcessingInterceptor();
	}
}

采用上面的两种配置之一后,重新运行服务,调用接口最大等待的响应时间为上面设置的120s。

三、需要避免踩到的坑

  如果按上述配置后,还是会出现超时情况,有可能是以下几种技术的问题,需要对应设置一下。

1、tomcat的设置

  上文中是springboot开发环境,使用了内置的tomcat。而在实际生产环境中一般用的是外置tomcat来部署(便于后续发布更新),需要在tomcat的配置文件server.xml中设置超时时间(默认20秒以下设置为120秒)。

    <Connector port="8811" protocol="HTTP/1.1"
               connectionTimeout="120000"
               redirectPort="8443" />
2、Nginx的设置

  如果服务端使用到Nginx做了反向代理转发请求,就需要在Nginx的配置文件nginx.conf中设置超时时间,否则会返回“java.io.IOException: 你的主机中的软件中止了一个已建立的连接”这样的异常提示。

  未设置时Nginx响应时间默认60秒,这里我将http头部的keepalive_timeoutclient_header_timeoutclient_body_timeoutsend_timeout 、以及server代码块中的proxy_read_timeout均配置为120秒。

http {
    include       mime.types;
    default_type  application/octet-stream;
    client_max_body_size 100m;
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';
 
    #access_log  logs/access.log  main;
 
    sendfile        on;
    #tcp_nopush     on;
 	
 	keepalive_time 300s;
    keepalive_timeout  300; #连接超时时间,服务器将会在这个时间后关闭连接
    send_timeout 300;    #发送超时时间
    client_header_timeout 300;    #请求头的超时时间
    client_body_timeout 300;    #请求体的读超时时间
    #gzip  on;
    #长连接
    map $http_upgrade $connection_upgrade {
        default upgrade;
        '' close;
    }
 
.....
 
    #业务系统的配置
    server {
        listen       9092;
        server_name  localhost;
	
    	location / {
             proxy_pass http://127.0.0.1:8811/mywebsev/;
	         #长连接
            proxy_connect_timeout 300;         #与upstream server的连接超时时间(没有单位,最大不可以超过75s)
            proxy_read_timeout 300;           #nginx会等待多长时间来获得请求的响应 秒
            proxy_send_timeout 300;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;
            }
    }
}

PS:正常配置在upstream,参数是在qps大的时侯使用,类似连接池。
Spring Boot是一种基于Spring框架的开发工具,可以帮助开发者快速搭建、配置和运行应用程序。它提供了很多有用的特性和功能,其中包括实现高吞吐量异步处理。 在Spring Boot中,我们可以通过使用异步处理来提高应用程序的吞吐量。异步处理允许应用程序在进行一些耗时的操作时不阻塞主线程,而是把这些操作交给线程池或者消息队列来处理。这样可以使应用程序更高效地利用系统资源,从而实现更高的吞吐量。 在Spring Boot中,我们可以使用`@Async`注解来标记需要异步处理的方法。例如,我们可以在Service层的方法上添加`@Async`注解,使其成为一个异步方法。当调用该方法时,Spring Boot会自动将其放入一个线程池中进行异步处理。 要使用异步处理,我们首先需要在Spring Boot中配置一个线程池。可以通过在配置类中使用`@EnableAsync`注解来启用异步处理,并通过`TaskExecutor`接口的实现类来配置线程池的参数,例如线程池大小、队列容量等。 通过使用异步处理,我们可以在主线程进行其他操作的同时,将耗时操作委托给其他线程或者消息队列来处理。这样就可以大大提高应用程序的吞吐量,同时保持应用程序的响应性。无论是处理大量并发请求,还是执行耗时的后台任务,异步处理都能帮助我们更好地优化应用程序的性能。 总之,Spring Boot通过提供异步处理的能力,帮助开发者实现了高吞吐量的应用程序。通过使用`@Async`注解和配置线程池,我们可以实现将耗时操作交给其他线程或者消息队列进行处理,从而提高应用程序的性能和吞吐量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值