-
Notifications
You must be signed in to change notification settings - Fork 114
阿里巴巴Dragonwell11用户指南
Jonathan Lu edited this page Dec 29, 2019
·
21 revisions
阿里巴巴有着最丰富的Java应用场景,覆盖电商,金融,物流等众多领域,世界上最大的Java用户之一。 作为OpenJDK的下游, Alibaba Dragonwell是阿里巴巴内部OpenJDK定制版AJDK的开源版本, AJDK为在线电商,金融,物流做了结合业务场景的优化,运行在超大规模的,100,000+ 服务器的阿里巴巴数据中心。 Alibaba Dragonwell与Java SE标准兼容,目前仅支持 Linux/x86_64平台。 Alibaba Dragonwell是OpenJDK的下游(friendly fork),使用了和OpenJDK一样的licensing。阿里会更紧密地和OpenJDK等开源社区协作, 贡献更多的patches, 促进Java技术的持续发展。
目前Alibaba Dragonwell 11只支持Linux x86-64平台,您可以通过如下步骤使用Alibaba Dragonwell 11
- 选项 1, 下载预编译的Dragonwell二进制包
- 从Alibaba Dragonwell的Github页面下载二进制tar包,链接 https://github.com/alibaba/dragonwell8/releases
- 将下载下来的tar包解压到目标安装目录即可
- 选项 2, 使用YUM工具安装
(施工中,即将到来) 只适用于RedHat, CentOS和AliOS等系统
- 添加阿里云的RPM仓库到您本地的/etc/repos.d/中
- 执行 yum makecache 更新YUM缓存
- 使用下面YUM命令安装Dragonwell
yum install dragonwell-11
将您的应用脚本或者环境变量中的JDK目录变量(一般是JAVA_HOME)指向上一步中安装的Alibaba Dragonwell 11目录。 重启应用以使用Alibaba Dragonwell JDK配置
TODO
- 迷你Heapdump支持
Alibaba Dragonwell允许您在使用
jmap
工具生成heapdump的时候忽略掉所有原始类型数组的内容,只dump出对象引用等信息,从而缩小生成的Heapdump文件大小。使用时,只需要给-dump
子命令添加mini
参数即可。
示例命令:
jmap -dump:live,mini,format=b,file=heap121.bin <PID>
-
-XX:ArrayAllocationWarningSize=<Size>
增加参数-XX:ArrayAllocationWarningSize=xxx
,默认值512M。当分配大对象的大小超过该值的时候,标准输出中打印大数组的分配堆栈,用来排查大数组分配导致的GC问题。
该参数可以通过jinfo动态修改:
// print the allocation stack if more than 1M array allocated
jinfo -flag ArrayAllocationWarningSize=1048576 <pid>
// back to default value(512M)
jinfo -flag ArrayAllocationWarningSize=536870912 <pid>
如果您需要获取关于Alibaba Dragonwell的支持信息,请首先查看Alibaba Dragonwell FAQ文档。 或者您也可以发送电子邮件到 [email protected] 寻找帮助。 您也可以使用钉钉扫描下面二维码加入群聊获取支持