SpringBoot重启后首次接口请求慢的问题

首次请求接口时 响应时间经常会达到 1-2秒

项目上线后影响不大,但解决了总不是坏事

我们可以配置一个Bean,在服务创建之后请求服务的某个接口,来完成服务的预热

如下:


import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpMethod;
import org.springframework.web.client.RestTemplate;

/**
 * 服务预启动
 * 解决服务首次调用过久的问题
 * @author 14501
 */
@Slf4j
@Configuration
public class LoadDataBase {

    /**
     * 注册RestTemplate
     * @param builder boot1.4之后提供的RestTemplate操作类
     *                也可以直接返回 new RestTemplate()
     * @return 返回注册的RestTemplate到Bean
     */
    @Bean
    public RestTemplate restTemplate(RestTemplateBuilder builder) {
        return builder.build();
    }

    /**
     * 当服务创建完毕后 直接调用Bean 完成服务的接口预热
     * @param restTemplate
     * @return
     */
    @Bean
    CommandLineRunner initController(RestTemplate restTemplate) {
        return args -> {
            log.info("REQUEST " + restTemplate.execute("http://127.0.0.1:9090/user/hello", HttpMethod.GET, null, null));
        };
    }
}

重启项目后,接口的首次调用响应时间变为 100-200ms,再次响应变为34ms:

参考文章:

SpringBoot重启后首次接口请求慢的问题_springboot首次访问接口慢_gnf_cc的博客-CSDN博客 

解决SpringBoot不能自动注入RestTemplate_no qualifying bean of type resttemplate_aisinilehehe的博客-CSDN博客

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱飞的男孩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值