写点什么

GraalVM 21 发布,引入使用 Java 开发的虚拟机

2021 年 2 月 08 日

GraalVM 21发布,引入使用Java开发的虚拟机

GraalVM21.0 主版本发布了,包含了一个新组件Java on Truffle,该组件提供了一个用 Java 开发的 Java 虚拟机(JVM)。GraalVM 本身是一个多语言虚拟机,提供了一个共享的运行时来执行用 Java、Python 和 JavaScript 等多种语言开发的应用程序。


在这个版本发布之前,在想在 GraalVM 上运行 Java 应用程序,可以使用带有 GraalVM 即时编译器(JIT)的 Java HotSpot VM 或者使用 GraalVM 原生镜像将代码编译成原生可执行文件。新版本的 Java on Truffle(一个基于Truffle框架、使用 Java 开发的 JVM)为运行 Java 应用程序提供了额外的选项。


Java on Truffle(代号 Espresso)可以通过 GraalVM 更新程序 gu 来安装。gu 是一个包管理器,用于下载和安装 GraalVM 核心发行版中不包含的包。


gu install espresso
复制代码


要通过 Java on Truffle 来运行 Java 应用程序,需要向 Java 命令传递-truffle 选项。


java -truffle -jar awesomeApp.jar
复制代码


Java on Truffle 是一种小型 JVM,提供了 JVM 的所有核心组件,比如字节码解释器、Java 本地接口(JNI)和 Java 调试线协议(JDWP)。它实现了 Java 运行时环境库(libjvm.so) API,重用了所有必需的 GraalVM JAR 包和原生库。就像传统的 JVM 一样,Java on Truffle 也支持运行其他基于 JVM 的语言,比如 Kotlin。



图片来源:GraalVM博客


因为它是用 Java 实现的,并且能够运行 Java,所以 Java on Truffle 本质上是自托管的 Java 或 Java on Java。这为研究和创新 JVM 提供了有趣的机会,因为 Java 开发人员可以阅读和理解 JVM 源代码,并对其加以改进。


下面是 Java on Truffle 提供的一些值得注意的特性和好处:


  • 在调试会话期间,利用增强的 HotSwap 功能在运行时修改方法、Lambda 和类的访问修饰符。

  • 能够运行不同于主机 JVM 的 Java 字节码版本。例如,可以通过Polyglot API在 Java 11 应用程序中调用 Java 8 的库。

  • 将宿主 JVM 和在 Truffle 上运行的 Java 应用程序隔离,运行不是很可信的访客代码。在这里,“宿主”和“访客”用来区分执行 Java 的不同的层。Java on Truffle 是访客层。

  • Java 应用程序可以与 JavaScript 和 Python 等非 JVM 语言直接互操作,并在相同的内存空间中来回传递数据。

  • 可以利用 Truffle 框架提供的标准工具。例如,可以使用 CPU 采样器分析工具来查看 Java 应用程序的哪个部分占用更多的 CPU 时间。

  • 构建预先编译(AOT)的 Java 原生镜像,动态加载和运行 Java 代码,使用 Espresso 的 JIT 编译器。例如,CI/CD 应用程序(如 Jenkins)可以被构建成原生镜像,同时又可以动态加载任意插件。



图片来源:GraalVM博客


GraalVM 提供了一组演示应用程序来展示这些特性和好处。


需要注意的是,Java on Truffle 是一个实验性组件,还不能用于生产环境中。Java on Truffle 当前版本的峰值性能比常规 JVM 慢了好几倍,但在后续版本中将得到改进。下面是一些值得注意的 Java on Truffle 限制,这些限制可能会在 GraalVM 的未来版本中得到解决:


  • 没有实现 JVM 工具接口(JVMTI)。不支持对应的“-agentlib”和“-agentpath”虚拟机选项。

  • 没有实现 java.lang.instrument 接口。不支持对应的“-javaagent”虚拟机选项。

  • 实现了部分 Java 管理扩展(JMX),有些方法可能只返回部分数据。


除了 Java on Truffle 之外,新版本还增强了其他功能。例如,现在允许在原生镜像二进制文件中使用 Java 序列化。在构建原生镜像之前,可以使用 javaagent 自动生成序列化配置。


新版本的 GraalVM 还为 Ruby、Python 和 LLVM 发行版提供了一些兼容性和运行时改进。GraalVM 的 WebAssembly 语言实现(GraalWasm)也得到了优化,提升了预热时间和 WebAssembly 的整体解释峰值性能。


GraalVM 社区版的 Java 版本更新了,基于 OpenJDK 1.8.0_282 和 OpenJDK 11.0.10。GraalVM 的 Node.js 版已经更新到 12.20.1。


在工具方面,GraalVM 21.0 附带了一个改进的 gu 工具,可以更简单地进行版本更新。Visual Studio Code 的GraalVM扩展包也已经发布,帮助开发和调试基于 GraalVM 的应用程序。


原文链接


GraalVM 21.0 Introduces a JVM Written in Java

2021 年 2 月 08 日 11:271934

评论 1 条评论

发布
用户头像
It is necessary to specify -XX:+IgnoreUnrecognizedVMOptions because Intellij automatically adds a -javaagent argument which is not supported yet.
1 小时前
回复
没有更多了
发现更多内容

应用程序研发之网络 - Http

superman

应用程序研发之网络-网络编程模型

superman

程序的机器级表示-访问数据

引花眠

ARTS打卡 第9周

引花眠

ARTS 打卡计划

门面效应 - 拒绝别人会产生愧疚吗?

石云升

心理学 门面效应 留面子效应

MySQL主从复制详解

Simon

MySQL 主从复制

耦合层:撮合物联网的理论与实践牵手的“月老”

华为云开发者社区

AI 物联网 IoT 低耦合 华为云

架构师训练营第八周课后总结

Cloud.

简易web性能工具

Arvin

C++编译过程 宏 内联和静态变量

正向成长

JDK1.8新特性(六):Stream的终极操作,轻松解决集合分组、汇总等复杂操作

xcbeyond

stream 集合 新特性 JDK1.8 Collections

MySQL 百万级数据量分页查询方法及其优化

xcbeyond

SQL优化 数据库优化

应用程序研发之网络-分层模型

superman

Jenkins 多分支项目过滤及 when 的高级用法

jerry.mei

DevOps 运维 自动化 jenkins CI/CD

轻松应对并发问题,Newbe.Claptrap 框架中 State 和 Event 应该如何理解?

newbe36524

分布式 微服务 架构设计 .net core ASP.NET Core

百万并发「零拷贝」技术系列之Linux实现

码农神说

Java 架构 零拷贝

Flink 使用大状态时的一点优化

Apache Flink

flink RocksDB

Java 8 中的函数式接口

陈皮

从零开始写一个迷你版的Tomcat

简爱W

ARTS 06 - Jenkins 多分支项目过滤及 when 的高级用法

jerry.mei

学习 算法 ARTS 打卡计划 CI/CD ARTS活动

封装element-ui表格,我是这样做的

前端有的玩

Java Vue Element 封装

云图说|“真人?机器?傻傻分不清!” WAF Bot管理,带你慧眼辨“精”!

华为云开发者社区

bootstrap 搜索引擎 安全 防火墙 华为云

第8周作业

小胖子

LeetCode题解: 206. 反转链表,JavaScript,容易理解的递归解释,详细注释

Lee Chen

LeetCode 前端进阶训练营

第8周-作业1

seng man

第8周-作业2

seng man

计算机的时钟(二):Lamport逻辑时钟

ElvinYang

5万字长文:Stream和Lambda表达式最佳实践-附PDF下载

程序那些事

Java jdk Lambda stream

读完《云原生架构白皮书》,我们来谈谈开放应用模型(OAM)

郭旭东

Kubernetes 云原生 OMA

初识进程coredump(以中间件为例)异常宕机

清康

安全系列之——手写JAVA加密、解密

诸葛小猿

对称加密 加密解密 非对称加密 rsa AES

微服务架构下如何保证事务的一致性

微服务架构下如何保证事务的一致性

GraalVM 21发布,引入使用Java开发的虚拟机-InfoQ