9月7日-8日,相约 2023 腾讯全球数字生态大会!聚焦产业未来发展新趋势! 了解详情
写点什么

静态 Java 现状:为提升启动速度、减少空间占用而编译的本地可执行文件

  • 2022-05-20
  • 本文字数:2176 字

    阅读完需:约 7 分钟

静态Java现状:为提升启动速度、减少空间占用而编译的本地可执行文件

静态 Java 生成静态编译的本地可执行文件(目标是加快启动速度和减少空间占用),磁盘占用和运行时的元数据开销都减少。InfoQ 采访了 Red Hat 首席软件工程师Dan Heidinga——他是静态 Java 相关工作的长期贡献者——以了解静态 Java 离广泛应用还有多远。

 

参与静态 Java 相关工作是因为他认识到,Java 需要演进,从而满足由云相关的新实践所驱动的不断变化的生态系统。目前,除了参与CRiU(用户空间的检查点/恢复)(包括 OpenJDK 的CRaC项目和 OpenJ9 的CRiU项目),为OpenJ9 JVMJava Lambdas做贡献,将方法句柄引入 Java,参与Valhalla项目,他在静态 Java 之旅中也走在了前列。

 

InfoQ:您好,Dan。感谢您抽时间来回答我们读者的多个问题。能否请您简单介绍一下自己,说明下您的日常职责以及您参与静态 Java 相关工作的情况?

 

Dan Heidinga:长期以来,我既是 JVM 开发者又是 Java 用户。我的日常工作是开发 Hotspot JVM(同时也是 OpenJ9 JVM 的项目负责人)和qbicc项目:一个实验性的 Java 程序静态编译器,可以作为尝试不同静态 Java 方法的游乐场,帮助探索整个设计空间,为 OpenJDK 的 Leyden 项目做准备。

 

我还积极参与了CRiU(用户空间的检查点/恢复)审查,包括 OpenJDK 的 CRaC 项目和 OpenJ9 的 CRiU 项目,因为我看到,检查点/恢复和静态 Java 的需求存在很多重叠。

 

InfoQ:静态 Java 有什么优势?最适合什么场景?

 

Heidinga:静态 Java 生成静态编译的本地可执行文件,旨在加快启动速度,减少空间占用,磁盘占用和运行时的元数据开销都减少。尽管它潜在的应用场景有很多,但微服务、CLI 应用和无服务器部署是最佳候选场景。

 

它提供以下几项能力:

1. 应用程序的所有 Java 代码均为本地编译。

2. 能够“关闭世界”防止其他类被加载。这可以消除死代码,去除不使用的方法和字段,从而使二进制文件更小。

3. 能够在构建时初始化应用程序的某些部分,以便进一步优化,避免在随后的启动中进行多余的工作。

 

主要的好处是可以从一个可执行的小部署包快速启动。启动速度加快是因为避免了 Java 的动态行为,如加载和验证类,并在第一次使用时解析每个字段和方法。还有就是利用构建时初始化将操作(如类的初始化)从运行时转移到构建时。

 

对于堆不大的应用程序来说,运行时空间占用改进最为明显,因为堆大小决定了类元数据所需的内存。

 

InfoQ:从 Java 经典的“动态虚拟机”模型迁移到静态 Java,对开发者有什么要求?

 

Heidinga:即使有了指南和工具,开发者也应该有个预期,就是将他们的应用程序转化为静态应用是一项需要花费相当精力的挑战。

 

静态 Java,顾名思义,比普通 Java 的动态性要低得多。因此,Java 的许多动态特性在使用时都会导致问题,如 Reflection、MethodHandles、类加载、字节码生成和 JVMTI 代理。一个比较好的选择是,从 GraalVM 的跟踪代理入手,创建支持在运行时使用这些动态特性所需的配置文件。静态 Java 的要求之一是限制动态特性,需要在构建时明确选择。

 

选择一个使用静态 Java 的框架(如 Quarkus、Micronaut)将使你能够利用它所带来的好处,而且可以避免许多采用静态 Java 的障碍。

 

InfoQ:静态 Java 已经在生产系统中应用了吗?

 

Heidinga:早期采用者在生产环境中使用了,但主要是在新开项目或非关键用例中使用,这可以帮助建立信心和积累知识。我觉得 OpenJDK Leyden 项目所做的模型标准化会有助于采用。目前为止,对于静态 Java,除了框架使采用路线更加平滑之外,入手还是比较难。

 

虽然据我估计,随着云端实践在行业中日益广泛,用户对其云部署的成本意识增强,静态 Java 的采用率将继续增长,但会比较缓慢,因为有很多软件将永远无法适应静态 Java 的要求(这也没关系!)。需要静态 Java 特性的用户则刚刚开始意识到这些特性对他们的部署有多重要。

 

为了真正推动主流的采用,Java 需要意识到当前正在发生的阶段性变化(构建时与运行时,检查点与恢复),为开发者提供工具,让他们可以使用这门语言表达自己的意思。我认为这即将到来,但考虑到现有 OpenJDK 项目的时间跨度,这可能需要一年多的时间。

 

Heidinga 认为,随着云计算的不断发展,以及人们对缩短启动时间和降低空间占用的需求,静态 Java 的旅程才刚刚开始。但是,Leyden项目的实施可能会加速它的采用。不过现阶段,他建议对其进行实验,并提到 Red Hat 杰出工程师Andrew Dinn所领导的实验。Heidinga 还表示,很难说 Leyden 项目在2020年审批通过后取得了多少进展,但是:

 

OpenJDK 项目及其周边社区正在进行大量的研究和探索,希望我们在不久的将来可以看到这些工作在 Leyden 项目中得以体现。

 

有几个项目与 Leyden 项目的问题空间存在重叠,比如 CRaC 项目,特别是关于“如何暴露 Java 编程模型的不同阶段”的问题。另外,GraalVM 社区在这段时间里也在继续改进SubstrateVM

 

对于那些在采用静态 Java 时遇到无法解决的问题,或者只是不想调整现有动态设计的人来说,仍然有望提升启动速度:与 CRiU 相关的工作(如 CRaC 项目)旨在探索静态和动态 Java 之间的另一个点。

 

作者简介:

Olimpiu Pop 是一名软件工程师,具有从财务软件到 IAM 的实时应用开发经验。她热衷于工具和开发流程优化。她担任着欧洲 IDaaS 组织 iWelcome 的工程总监。她是 Transylvania JUG 协调人,Voxxed 罗马尼亚项目委员会成员,并有望在不久的将来成为发言人。同时,她还是 JavaAdventCalendar 的主编。

 

原文链接:

Static Java Current State: Compiled Native Executables for Startup Speed and Small Footprint

活动推荐:

2023年9月3-5日,「QCon全球软件开发大会·北京站」 将在北京•富力万丽酒店举办。此次大会以「启航·AIGC软件工程变革」为主题,策划了大前端融合提效、大模型应用落地、面向 AI 的存储、AIGC 浪潮下的研发效能提升、LLMOps、异构算力、微服务架构治理、业务安全技术、构建未来软件的编程语言、FinOps 等近30个精彩专题。咨询购票可联系票务经理 18514549229(微信同手机号)。

2022-05-20 09:343602

评论

发布
暂无评论
发现更多内容

HashMap源码分析(一)

知识浅谈

hashmap 10月月更

无法吃午餐的学生数量

掘金安东尼

算法 10月月更

Linux下IIC驱动编写,介绍IIC子系统框架的使用

DS小龙哥

10月月更

C++中变化布局实现思路

中国好公民st

c++ 布局 10月月更

React面试八股文(第二期)

beifeng1996

React

OKR之剑·理念篇03:OKR理念认同

vivo互联网技术

团队管理 OKR 目标管理

前端关于面试你可能需要收集的面试题

loveX001

JavaScript

react源码分析:babel如何解析jsx

flyzz177

React

你知道Redis为什么要设计成单线程吗

芥末拌个饭吧

后端 redis 底层原理 10月月更

react源码中的fiber架构

flyzz177

React

promise执行顺序面试题令我头秃,你能作对几道

loveX001

JavaScript

js异步编程面试题你能答上来几道

loveX001

JavaScript

华为云从入门到实战 | 云速建站服务与企业主机安全服务

TiAmo

华为 华为云 云开发 10月月更

React源码分析1-jsx转换及React.createElement

goClient1992

React

React组件之间的通信方式总结(下)

beifeng1996

React

Linux下RTC驱动开发(硬件采用DS1302)

DS小龙哥

10月月更

Lerna最佳实践(内含大量代码)

鲸品堂

代码 lerna

Redis是如何保证数据一致性的

芥末拌个饭吧

后端 redis 底层原理 10月月更

React组件之间的通信方式总结(上)

beifeng1996

React

CEF | CEF浏览器客户端功能扩展:实现前进、后退、刷新、调用控制台、设置cookie、网页自适应窗体大小

YOLO.

qt 10月月更 C++

Linux下驱动开发_块设备驱动开发(内存模拟存储)

DS小龙哥

10月月更

Linux下驱动开发_块设备驱动开发(硬件上采用SD卡+SPI协议)

DS小龙哥

10月月更

react源码分析:组件的创建和更新

flyzz177

React

掌握这个方法,让工作经验配得上工作时间!

博文视点Broadview

谈谈spark性能调优的方法

芥末拌个饭吧

spark 后端 10月月更

一种基于柔性事务的分布式事务解决方案设计探究

京东科技开发者

分布式事务 事务 分布式架构 事务回滚 分布式处理

react源码中的协调与调度

flyzz177

React

React源码分析2-深入理解fiber

goClient1992

React

CEF | CEF浏览器客户端功能扩展:实现下载列表功能

YOLO.

qt 10月月更 C++

Java中的接口详解

共饮一杯无

Java 接口 10月月更

数据驱动型企业如何借助「新一代智能协作」提升研发效能?

LigaAI

人工智能 数据驱动 亚马逊云科技 企业号十月PK榜

  • 扫码添加小助手
    领取最新资料包
静态Java现状:为提升启动速度、减少空间占用而编译的本地可执行文件_编程语言_Olimpiu Pop_InfoQ精选文章