Java程序启动后首次访问很慢--JVM预热

目录

导读

为什么刚启动发起的请求会有损?

如何预热

小结 


导读

     在项目部署或者重启后,机器挂到线上直接承接线上流量,会出现请求有损或者请求性能极差的情况,表现形式:max高,请求失败等,几次请求过后,线上各项指标恢复正常。 那么为什么会造成这样的情况?以及如何解决呢?

为什么刚启动发起的请求会有损?

         当应用的第一个请求到来,会触发逻辑相关类的第一次加载,此过程会有一定的耗时,会影响第一次调用的实时响应。这主要是因为JVM的懒加载及JIT机制
 

如何预热

     预热的目的是什么:

                降低对用户请求的损耗

     预热的核心思想是什么:

                Java程序启动后 用非线上真实用户的请求来预先进行请求,进行预热后再承接线上流量

      预热方式举例:

                可以写一个脚本,在java程序启动后执行调用, 启动成功之后sleep 2分钟等tomcat启动完全,端口8001已经打开监听,然后循环调用接口10次,进行预热。

sleep 120s
for i in `seq 10`; do
   curl --location -g -I --request GET 'http://127.0.0.1:8080//XXXX/YYYYY?body=ZZZZZ'
done

            若tomcat未启动完全可能会出现如下结果,sleep时间再加长些试试

            

小结 

     学习到的思想,预热的核心细想, 脚本的灵活运用,这个问题虽小,但很重要

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值