[转帖]阿里的JDK预热warmup过程

预热warmup过程

https://blog.csdn.net/wabiaozia/article/details/82056520

Jwarmup 原理是记录上一次运行时已经变成native code 的class function 以及加载顺序 然后 下一次打开时 避免JIT的过程 直接进进行编译. 

https://blog.csdn.net/feelwing1314/article/details/80359785

今天群里小伙伴黄晓峰VIVO咨询一个问题:”dubbo接口怎么做预热呢,每次上线,都会有一小部分超时?”,熟悉JVM都知道,JVM重启后有一段预热过程,要运行一段时间,它的性能才能达到最佳状态;阿里JVM团队就针对这个缺陷进行了优化,其特性名曰:jwarmup,可以点击Alibaba JVM创新提效 获国际社区认可登台JVM圈顶会,对jwarmup稍微了解;

你假笨那里了解到jwarmup的大概原理:针对上次JIT对应用的优化,主动去触发JIT编译优化,而不是等jvm运行一段时间自己去感知!

介绍alijdk辅助工具JITWarmup

JVM在应用启动的时候因为没有jit的充分参与,性能没有达到最优状态,同时在这个过程中要不断重新编译,优化。占用非工作线程以外的大量资源,会使在

启动阶段load骤然升高,很多时候我们会采用分层编译来解决。但是分层编译启用后,c1的cacheocde会占用大量的空间,又会引发jvm崩溃的问题。(http://bugs.java.com/bugdatabase/view_bug.do?bug_id=8006952)

现在alijdk有了一个辅助工具JITWarmup,使用它可以记录上一次(最好是beta发布)运行时被编译的方法名字,类初始化顺序,执行次数等信息,在下次

启动(正式发布)的时候,读取这些信息,然后JIT对应的方法。

图上(1)是启动初期,应用并没有提供服务的时候,也就是jvm启动时并没结束,所以这个高峰并不影响服务(启动时间可能延长了)。但是在后面,蓝线是原来启动时cpu的load,一直居高70s左右,红线是使用JITWarmup后cpu居高情况,很快就下来了。效果还是非常明显的。

JitWarmUp更名为JWarmup正式内置为AJDK模块。

JWarmup是AJDK-8.1.1引入的新功能(Preview),曾用名JitWarmUp,在AJDK-8.2.3中正式发布(建议使用 AJDK8.2.4_fp1 or higher )。通过记录Java应用上一次运行时候的编译信息到文件中,在下次应用启动时,读取该文件,从而在流量进来之前,提前完成类的加载、初始化和方法编译,从而跳过解释阶段,直接执行编译好的native code,避免一面解释执行一面后台编译带来的CPU与load飙高,rt超时等问题。

原文地址:https://www.cnblogs.com/jinanxiaolaohu/p/11614819.html

时间: 2024-11-07 22:33:18

[转帖]阿里的JDK预热warmup过程的相关文章

阿里云服务器ECS配置过程

公司托管主机改为阿里云ECS,借机记录一下配置过程,以后也好直接拿来使用~ 进入系统需要4种密码,阿里云的登录密码(自己设),连接管理终端密码(阿里云给,6位数字),远程桌面密码(大写,小写,数字) 1.登录阿里云,导航到ECS,实例,找到服务器的公网IP,远程登录 2.进入系统,格式化非系统盘,默认为没有格式化的状态 3.服务器管理器仪表板,配置此本地服务器,点击计算机名,修改,重启生效.Windows Server 2012的重启在类似于win8的右侧浮动边栏. 4.添加角色和功能,基于角色

阿里云ECS架设VPN过程总结

原文地址: http://blog.csdn.net/johnnycode/article/details/45543157 最近开发移动项目,数据库服务是架设在电信服务器上,可怜我的联通网络本地调试直接x碎了一地!! 度娘相关资料后,最终决定在阿里云ECS上架设VPN作为跳板来访问电信服务器! 一.原理 1.阿里云ECS上架设VPN. 2.本地连接使用VPN拨号到阿里云ECS. 3.使用阿里云ECS网络访问电信服务器. 使用VPN前效果 64 bytes from xxx.xxx.xxx.xx

Linux下JDK+TOMCAT安装过程

1.安装JDK的步骤如下: 网上查的安装步骤如下: 1)下载j2sdk ,如jdk-6u1-linux-i586-rpm.bin 2)在终端中转到jdk-6u1-linux-i586-rpm.bin所在的目录,输入命令 #chmod +x  jdk-6u1-linux-i586-rpm.bin://添加执行的权限. 3)执行命令 #./jdk-6u1-linux-i586-rpm.bin://生成jdk-6u1-linux-i586.rpm的文件. 4)执行命令 #chmod +x  jdk-6

Java之JDK环境配置过程(图)

1.在Windows7操作系统下,右键,点击属性,会出现如下界面 2.选择"高级系统设置",如下 3.接着点击"环境变量"按钮,会出现如下图: 4.找到系统变量,点击"新建"按钮,这时会弹出一个窗口,分别在变量名和变量值框中填入:JAVA_HOME和JDK的路径C:\Program Files\Java\jdk1.7.0_05,点击"确定": 5.同样在系统变量下点击"新建"按钮,再次弹出一个窗口,分别在变

Dubbo 源码分析 - 集群容错之 LoadBalance

1.简介 LoadBalance 中文意思为负载均衡,它的职责是将网络请求,或者其他形式的负载"均摊"到不同的机器上.避免集群中部分服务器压力过大,而另一些服务器比较空闲的情况.通过负载均衡,可以让每台服务器获取到适合自己处理能力的负载.在为高负载的服务器分流的同时,还可以避免资源浪费,一举两得.负载均衡可分为软件负载均衡和硬件负载均衡.在我们日常开发中,一般很难接触到硬件负载均衡.但软件负载均衡还是能够接触到一些的,比如 Nginx.在 Dubbo 中,也有负载均衡的概念和相应的实现

[转帖] 部分收费的Oracle JDK VS 完全免费的OpenJDK

来源: http://www.flammulina.com/2018/10/28/%E9%83%A8%E5%88%86%E6%94%B6%E8%B4%B9%E7%9A%84oracle-jdk-vs-%E5%AE%8C%E5%85%A8%E5%85%8D%E8%B4%B9%E7%9A%84openjdk/ 本文将讨论Oracle JDK和OpenJDK之间的区别.注意目前 OpenJDK 和 Oracle JDK 仅由Oracle创建和维护.在详细介绍之前,让我们回顾一下JDK是什么,在开始对比

阿里云服务器被植入恶意插件解决过程

问题发现: 国庆放假期间公司一台阿里云服务器发现无法正常登陆,报错信息提示22端口未开放.且服务器提供的jenkins服务是正常可以使用的,部分功能缺失,于是登陆阿里云控制台使用远程终端管理登陆服务器,发现输入对的用户名及登陆口令无法登录进系统,而且一直提示让重复登录,无法正常登陆进系统内部,很是困惑,第一次遇到这种奇葩的问题,有种束手无策的感觉. 问题解决经过: 开始联系了阿里云的系统工程师申请技术支持,因目前系统处于无法登录状态,所以将服务器的登录口令及远程密码授权给了阿里云的工程师,下面是

阿里开源自用 OpenJDK 版本,Java 社区迎来中国力量

3 月 21 日,阿里巴巴将宣布开源 Alibaba Dragonwell.届时,开发者可通过阿里云开发者中心及 Github 社区下载使用.InfoQ 记者独家专访了阿里云智能基础产品事业部资深技术专家李三红.阿里云智能基础产品事业部研究员 Kingsum Chow (周经森),听他们如何看待 Alibaba Dragonwell 与 Java 归途. 作者 | 赵钰莹受访嘉宾 | 阿里云智能基础产品事业部资深技术专家 李三红阿里云智能基础产品事业部研究员 Kingsum Chow (周经森)

阿里开源 OpenJDK 发行版 Dragonwell

日有消息显示,阿里将于 21 日重磅发布其 OpenJDK 发行版 Alibaba Dragonwell. 我们知道 OpenJDK 是基于 GPL v2/Classpath Exception 的 JDK 开源版本,有许多公司都在 OpenJDK 的基础上提供了自己的发行版,比如 Oracle.AdoptOpenJDK.Azul.IBM 与 Red Hat,一般这些供应商会将自行衍生的 OpenJDK 版本加入一些商业/非商业支持选项. 去年 AWS 也推出了自己的 OpenJDK 发行版 C