SpringBoot重启后,第一次请求接口请求慢的解决方案

1、DispatcherServlet默认是懒加载,即工程启动的时候,Applicationcontext会将所有的bean加载到容器,但是DispatcherServlet是没有加载的,只有第一次访问的时候才会加载
场景一:DispatcherServlet懒加载情况,启动的时候如下图
在这里插入图片描述只有一个ApplicationContext的初始化,此时并没有DispatcherServlet的初始化,接下来我们进行一次接口调用,如下图:
在这里插入图片描述
发现在进行接口调用的时候,才初始化了DispatcherServlet,接下来我们再进行一次接口调用,如下图:
在这里插入图片描述
此时,直接进行方法的调用和返回。

场景二:spring.mvc.servlet.load-on-startup=1
DispatcherServlet关闭懒加载,启动的时候如下图:
在这里插入图片描述
同时完成了ApplicationContext和DispatcherServlet的初始化,此时再进行接口调用,会发现即便是第一次调用,也直接进入了方法,如下图:
在这里插入图片描述
通过上述测试可知,通过配置 spring.mvc.servlet.load-on-startup=1 关闭DispatcherServlet懒加载,使第一次接口访问的时候直接进行方法的调用,提高速度

2、随机数生成慢的原因和解决方案。Java随机数生成依赖熵源(Entropy Source),默认的阻塞型的 /dev/random熵源可能导致阻塞,而换一个非阻塞的 /dev/urandom的熵源就可以了。

解决方法:

临时、方便
以这种方式运行jar包 java -Djava.security.egd=file:/dev/./urandom -jar XXX.jar XXX

永久
进入你的JAVA_HOME的jre目录下找到并vim编辑这个文件:
$JAVA_HOME/jre/lib/security/java.security

找到:
securerandom.source=file:/dev/random 这一行
改之前:
securerandom.source=file:/dev/random

改为:
securerandom.source=file:/dev/urandom

3、进行异步处理,提高整体的响应时间

4、加入缓存,例如热点数据的预加载等,提高响应时间

5、工程启动之后,就进行一次访问

@Slf4j
@Configuration
public class LoadDatabase {

    @Bean
    CommandLineRunner initController(RestTemplate restTemplate) {
        return args -> {
            log.info("REQUEST " + restTemplate.execute("http://127.0.0.1:9999/t1", HttpMethod.GET, null, null));
        };
    }
}


  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值