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)); }; } }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
关于mybatis3中@SelectProvider的使用问题
这篇文章主要介绍了mybatis3中@SelectProvider的使用技巧,@SelectProvide指定一个Class及其方法,并且通过调用Class上的这个方法来获得sql语句,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2021-12-12MyBatisCodeHelperPro插件下载及使用教程详解
这篇文章主要介绍了MyBatis CodeHelperPro插件使用教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧2020-09-09AbstractQueuedSynchronizer(AQS)锁状态同步和排队管理
这篇文章主要介绍了为大家AbstractQueuedSynchronizer(AQS)锁状态同步和排队管理源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11
最新评论