简介: 你要知道的关于Alibaba Dragonwell一些重要优化措施。

今年四月五日,阿里云开放了新一代ECS实例的邀测[1],Alibaba Dragonwell也在新ECS上进行了极致的优化。相比于之前的dragonwell_11.0.8.3版本,即将发布的dragonwell_11.0.11.6在SPECjbb2015[2] composite模式测试中,系统吞吐量max-jOPS提升55%,响应时间约束下的系统吞吐量critical-jOPS提升602%

如下图所示,图中数据做了归一化处理,以11.0.8.3_GA的critical-jOPS为1个基准单位。测试环境:阿里云80核,256g内存ECS实例,操作系统为Alinux3 [3]。

Alibaba Dragonwell

过去的十几年中,Java在阿里巴巴内部迅猛发展。阿里内使用Java语言编写的应用越来越多,数万的Java开发者每年产出超过十亿行Java代码,这些代码都运行在阿里巴巴内部的OpenJDK定制版AJDK上。

Alibaba Dragonwell是AJDK的开源版[4](github链接见文章末尾),使用和OpenJDK一样的License,并永久免费。Alibaba Dragonwell有8和11两个版本,于2019年开源,当时仅支持x86-64架构,在2020年扩展到AArch64平台。

Alibaba Dragonwell结合阿里在线电商、金融、物流等各个业务场景做了大量细致优化,添加了协程/多租户/Jwarmup等诸多自研特性,并且在阿里云超大规模的服务器集群上经受了长时间大规模的验证。

调优方案与工具

由于SPECjbb2015动辄就需要两个小时才能得到一次完整的跑分分数,为了压榨性能调优单位时间内我们所能获得的信息量和性能试验的效率,我们开发了自动测试平台和性能分析工具来辅助SPECjbb2015性能调优,并且这套方法可以用在未来更多类似的性能调优案例中。

自动测试平台可以自动发起测试,并且在测试过程中调用基于perf的性能分析工具来采集CPU微架构数据以及系统热点数据,从而收集到每次实验过程中的关键性能数据,并将数据存档以可视化界面的形式展现,方便未来回顾和分析。

同时为了避免SPECjbb2015单次实验耗时长影响效率,跑性能实验时我们采用了SPECjbb2015特殊的PRESET模式。该模式下可以指定压力指定时间来启动性能测试,不仅方便调优系统进行性能采集,还可以观察在一定压力下SPECjbb2015的系统热点和微架构数据情况。

我们通过该套调优系统获取到了Alibaba Dragonwell和其他JDK在跑SPECjbb2015时的热点和微架构数据,并且发现了诸多优化机会,如在GC热点和暂停时间上有较为明显的问题,从而深入到相关代码,并以性能数据为线索解决了相关的性能问题,具体的技术细节将在下文中向大家一一道来。

GC暂停时间优化

这项优化源于一个出人意料的发现,在SPECjbb2015中GC暂停时间竟然超过了总运行时间的20%,并且稳定复现。

通过上一小节中提到的调优系统,定位到出问题的是一个GC任务队列相关函数,并且明确的指向了原子Compare and Swap(CAS)相关代码。

新ECS采用的CPU架构中CAS主要有如下的两种实现方式:

  • 使用带load-aquire和store-release语义的指令对的实现方式
  • LSE指令集中的CAS专项指令

多数JVM在GC中使用第一种方法,然而第二种在高冲突的情况下性能更加出色,因此Dragonwell改变了编译方式,使用LSE指令集实现CAS,有效的减少了暂停时间。下图展示了优化效果,我们采集了SPECjbb2015运行在不同核数上的GC数据,并采用吞吐量作为衡量GC性能的指标。

吞吐量 = (运行时间 – Stop-The-World时间)/运行时间 * 100%

我们可以看到优化前的CAS方式会造成吞吐量随使用的核数增加而剧烈下降,在80核的情况下甚至不足80%,而使用LSE CAS后吞吐量稳定在99%以上

对这个优化的另外两点补充说明:

1. 此改动只针对JVM内部的CAS实现,不包括JIT(Just-In-Time)生成的代码。JIT会动态检查硬件特性,在支持LSE指令集的系统上会优先使用LSE指令集。

2. 除了使用LSE CAS外,改变GC队列算法减少CAS也可以达到减少暂停时间的效果,OpenJDK社区在新版本中采用了这种方法。不过两种办法并不冲突,Alibaba Dragonwell同时采用了两种优化,达到了最优效果。

快速序列化

Alibaba Dragonwell在保证兼容性基础上对java原生序列化进行了优化通过缓存大幅提高了性能。通过分析发现, 原生序列化瓶颈大多在于大量的class 查找,如在反序列化时需要获取对端类定义的元信息等。引入了一层通过类全限定名和类加载器映射到java类对象的缓存,减少了大量Class.forName的调用。

具体做法:在反序列化时获取到类描述符,再根据类描述符查找信息时将会受限从classCache中查找,命中则立即返回,如果没有找到当前classloader和类全限定名唯一指定的类对象,将会走默认的类查找流程并且将结果缓存。同时, 在反序列化时会大量调用latestUserDefinedLoader 来查找首个用户定义的类加载器,因为此过程较重(涉及一次JNI调用和爬栈)也进行了缓存。

指令融合

指令融合是指将多个指令使用效率更高的一条或者几条指令进行替换从而提高性能。

Dragonwell对内存屏障/内存读写/比较跳转等多个场景做了优化,由于篇幅限制而且此类优化原理较为类似,在此仅举一例,三条指令融合成一条,如下图所示。

上面介绍了Alibaba Dragonwell内部的一些优化,下面我们换一个角度,从参数调优方面介绍对SPECjbb2015的优化。

大内存系统开启压缩指针

SPECjbb2015是一个内存敏感型的测试,压缩指针对SPECjbb2015分数的提升非常明显。不过默认情况下使用压缩指针最大只能用32g内存,这对80核的系统来说实在是太小了。其实通过适当的参数组合,我们完全可以在更大的内存中使用压缩指针。

首先我们了解下压缩指针的基本原理。如上图所示,由于Java对象有明确的对齐要求,因此对象的地址必然由数个0结尾,0的个数由对齐位数决定。省略java对象地址结尾的数个0可解决内存而且不会丢失有效地址信息,需要访问对象时可以通过补0获得完整的地址。

由此可知,我们可以通过调整Java对象对齐位数控制压缩指针生效的最大内存。默认情况下Java为8字节对齐(3bit),加上压缩指针本身的的32bit,最多只能表示32g内存。但如果调整为32字节对齐,那么有37bit可以使用,也就是128g,这对于80核来说基本上够用了。

分层编译调优

分层编译是JVM最基础的机制之一,一般情况下对它改动比较少,不过在SPECjbb2015的场景下,在分层编译上仍有调优空间。首先介绍下分层编译。JVM在运行的时候动态的将字节码编译成机器码执行,JVM(hotspot)内部编译引擎主要有三个:

  1. 解释器:无编译开销,但解释执行效率很低。
  2. C1编译器:编译开销较低,生成代码质量一般。
  3. C2编译器:生成代码质量很高,但编译开销很高。

这三个编译引擎相互配合,执行次数较少的代码由解释器和C1负责,C2只编译热点代码,从而让Java可以达到峰值性能与编译开销的平衡,使应用运行更加平滑。

不过分层编译也有自己的缺点,一个较为明显的问题是它会增大生成代码的总量。下图展示SPECjbb2015运行时C1/C2编译方法数目。

图中Level1-3均为C1编译,根据收集运行信息的力度不同分为了三个等级,Level4为C2编译。我们可以看到C1编译了70%的方法,因此关闭分层编译,仅保留C2编译器可以减少生成代码,从而一定程度上提高高速缓存和叶表命中率。

对于SPECjbb2015来说,由于分数只取决于最后几分钟的峰值处理能力,前面大概两个小时的请求爬升阶段都可以视作预热,因此启动期的编译开销并不关键。我们可以关闭分层编译来减少生成代码,提高高速缓存和列表命中率。最终在测试中发现关闭分层编译生成代码总量由29M降低到9M,有明显减少。

本文总结了Alibaba Dragonwell的一些重要优化措施,请注意阿里承诺会持续的优化Dragonwell性能,同时更紧密地和OpenJDK等开源社区协作,贡献更多的定制化特性,促进Java技术的持续发展。

引用

[1] https://www.aliyun.com/daily-act/ecs/ecs_arm
[2] SPECjbb2015是一款模拟电商应用的权威基准测试程序,包含了购买下单、折扣优惠、库存计算、客户数据存储与分析等典型电商应用行为:https://www.spec.org/jbb2015/
[3]Alinux3:Alibaba Cloud Linux是阿里云推出的Linux发行版,它为云上应用程序环境提供Linux社区的最新增强功能,在提供云上最佳用户体验的同时,也针对阿里云基础设施做了深度的优化https://help.aliyun.com/document_detail/212631.html
[4] Alibaba Dragonwell是阿里巴巴开源JDK:https://github.com/alibaba/dragonwell8https://github.com/alibaba/dragonwell11

云上年中钜惠注册抽好礼!
8月31日前,用户注册登录阿里云即可抽iPhone12 Pro、Cherry机械键盘、天猫精灵等好礼!马上点此免费抽奖:http://click.aliyun.com/m/1000289891/

原文链接
本文为阿里云原创内容,未经允许不得转载。

JVM性能提升50%,聊一聊背后的秘密武器Alibaba Dragonwell相关推荐

  1. 天天动听MP3解码器性能提升50%

    天天动听今日升级提醒,发现有一句 "使用新的MP3解码器,性能提升50%",太惊讶了. 之前版本的MP3解码器使用libmpg123,效果已经是MP3解码器中非常不错的了. 50% ...

  2. 史上最全图解JVM,京东小哥带你了解性能提升100%背后的秘密武器

    工具概述 使用命令行工具或组合能帮您获取目标Java应用性能相关的基础信息,但它们存在下列局限: 1.无法获取方法级别的分析数据,如方法间的调用关系.各方法的调用次数和调用时间等(这对定位应用性能瓶颈 ...

  3. ES 搜索优化测试 - indexSort 对检索性能提升50%

    indexSort 是在写入数据的时候,根据某个字段做排序.我们可以理解为数据的预排序. 在检索的时候,假如搜索正好是根据排好序的字段做排序的,那么将会有 50%的 检索性能提升效果. 注意,不要在请 ...

  4. 华为P20背后的秘密武器

    4月12日,华为P20在国内闪耀登场,除了超酷的硬件和惊世的拍照技能外,作为华为第四代AI智慧终端,P20的AI能力展现也成为一大亮点.无论是基于Mater AI场景分析能力,超强的拍照模式,还是推荐 ...

  5. 华为麒麟1020处理器曝光:性能提升50%,5nm制程!Mate 40有望成为首发机型

    前不久,高通刚刚宣布新旗舰级骁龙865.性能级765/骁龙765G,华为麒麟就传来了新消息.虽然华为麒麟990系列芯片才发布没多久,但是下一代旗舰处理器的消息也已经接踵而来,对于外界来说,下一代产品的 ...

  6. win10多核与linux多核,win10拖后腿,Linux下线程撕裂者处理器性能提升50%

    AMD的第二代Threadripper处理器已经发布两天了,其中的旗舰Threadripper 2990WX成为桌面处理器市场上首款32核64线程处理器,相关评测也发布了,大家能看到32核处理器在多核 ...

  7. 刚刚,旷视开源深度学习框架「天元」:Brain++内核,研发和落地都在用;孙剑:COCO三连冠背后的秘密武器...

    乾明 发自 凹非寺  量子位 报道 | 公众号 QbitAI 耗费资源打造优化6年,迭代到8.0版本,旷视技术体系的关键支柱,现在正式对外开源. 刚刚,深度学习驱动之下最早创业的中国AI独角兽旷视,宣 ...

  8. 贝壳上市背后的秘密武器-ACN

    这是我的第18篇原创 贝壳上市了! 贝壳周四在美上市,IPO首日收盘大涨87.2%,股价报37.44美元,市值422亿美元.很多人都很惊讶,这是什么鬼?之前都没听说过,哪里冒出来的贝壳?市值比百度(4 ...

  9. 阿里云数字巡展:“云上峰会”背后的秘密武器

    简介: 近日,阿里云官网上线了叫做"数字巡展"的新产品,专为各行业在数字化创新提供解决方案.数字巡展,立足于设计创新,融合定制化虚拟空间.沉浸化技术体验.数字化企业营销三大核心能力 ...

最新文章

  1. What-If 工具:无需写代码,即可测试机器学习模型
  2. 时间序列的自回归理论和实现
  3. 关于树论【LCA树上倍增算法】
  4. 设计模式のObserver Pattern(观察者模式)----行为模式
  5. AOP - PostSharp 2.0
  6. Android edittext限制字节数
  7. 资源集 - 收藏集 - 掘金
  8. TCP控制字段标志:URG、ACK、PSH、RST、SYN、FIN
  9. android视频录制(调用系统视频录制),生成缩略图
  10. 统计平方和三元组的数目
  11. Kubernetes详解(六)——Pod对象部署和应用
  12. 【计算机网络】数据通信的基础知识
  13. HTML5期末大作业:我的家乡网站设计——我的家乡-杭州(7页) HTML+CSS+JavaScript 大学生家乡网页作品 老家网页设计作业模板 学生网页制作源代码下载
  14. Super超级ERP系统---(7)货位管理
  15. 新买的固态硬盘写保护,无法格式化,怎么破!
  16. 03、江苏专转本(专业课笔记)第三章、计算机软件
  17. springboot2.0整合redis报错
  18. java解压出来损坏_ZipOutputStream创建损坏的(可解压缩的)zip文件
  19. 无人机与地面站如何通信
  20. 实现epub中链接脚注加1的操作

热门文章

  1. 所有的图放到一个html,拖放是HTML5标准的组成部分,若想要把drag1图片放入d
  2. java观察者模式本质_6.[研磨设计模式笔记]观察者模式
  3. 初学Java编程经常遇到的问题,你们遇到过吗?
  4. java实验金额转换_java 数字金额转换中文金额
  5. c位边上还有什么位_c位是什么意思?C位说法的由来是什么?c位旁边二个位置叫什么?...
  6. python实现数据恢复软件_pyinstaller还原python代码过程图解
  7. views 多个文件夹 netcore_.NET Core 分发打包
  8. java版的中世纪战争_世界战争英雄设置-火焰纹章英雄英雄地图及AI命令设置
  9. arm b bl 地址无关码_ARM汇编语言入门(六)
  10. 可视化排班管理_小白经理的思考日记-可视化看板和走动管理