简化 Java 应用的升级:Eclipse Migration Toolkit for Java(EMT4J)

作者 | Johan Janssen 译者 | 张卫滨 策划 | 丁晓昀

Adoptium 发布了 Eclipse Migration Toolkit for Java(EMT4J),这是一个开源的 Eclipse 项目,能够分析和升级应用的 Java 版,以便于从 Java 8 升级至 Java 11,从 Java 11 升级至 Java 17。EMT4J 将支持升级到未来的 LTS 版本。

很多组织都建议使用最新的 Java 运行时,以获取安全性和功能方面的改进。同时,长期支持(Long Term Support)的 Java 版本每两年发布一次,Spring Framework 6 等项目已经至少需要 Java 17。令人遗憾的是,新 Java 版本的采用是相对缓慢的。例如,在 2022 年,也就是 Java 11 发布四年之后,只有不到 49% 的 Java 应用在使用该版本。

将应用升级至较新的 Java 版本意味着开发人员需要解决 Java 内部变更和功能移除所带来的所有问题。这涉及的功能包括 Nashorn、J2EE 和 Java 等包的移除、API 的变更以及对 Java 内部访问更严格的限制。

EMT4J 提供了一个支持 Maven 插件(目前在 Maven 中央仓库尚不可用)、Java 代理以及命令行的解决方案,以便于分析项目与新版本 Java 的不兼容性,结果会以 ** TXTJSONHTML** 格式输出。

为了演示 EMT4J,考虑如下的样例应用,它调用了 Java 11 中已经删除的 ** Thread.stop() **方法:

Thread thread = new Thread();thread.stop();

在克隆 Git 仓库并将 Maven 工具链配置为 JDK 8 和 JDK 11 之后,可以采用如下命令构建项目:

mvn clean package -Prelease

这将会在emt4j-assembly/target目录生成一个** .zip ** 文件,该文件可以进行解压。在解压后的目录中,就可以进行分析了。例如,在命令行中运行如下的命令:

java -cp "lib/analysis/*" org.eclipse.emt4j.analysis.AnalysisMain -f 8 -t 17     -o java8to17.html /home/user/application/classes

这将会分析指定目录下的类文件并在java8to17.html
文件中显示从 Java 8 升级到 Java 17 时的潜在问题。另外,也可以使用归档文件解压后在bin
目录下的** .bat .sh 脚本来启动命令行分析。README 文件描述了分析类和 JAR ** 文件的所有可用选项。

由此生成的 HTML 文件将会展示描述、解决方案和问题的位置:

1.1 Removed API Back to Content1.1.1 DescriptionMany of these APIs were deprecated in previous releases and     have been replaced by newer APIs.1.1.2 How to fixSee corresponding JavaDoc.1.1.3 Issues ContextLocation: file:/home/user/application/classes/App.class,     Target: java.lang.Thread.stop()V

除此之外,在 Java 应用启动的时候,可以使用 EMT4J 代理,或者在构建应用的时候使用 Maven 插件。

该项目包含了从 Java 8 升级至 11 和从 Java 11 升级至 17 的规则集。例如,用于校验应用是否使用 JDK 内部 API 的 JDK 内部 API 规则:

<rule desc="JDK internal API" type="reference-class"       match-type="by-package" class-package-file="jdk_internals.cfg"    result-code="JDK_INTERNAL" must-contain-in-bytecode="true"    sub-result-code="@{subResultCode}" priority="p4">    <support-modes>        <mode>agent</mode>        <mode>class</mode>    </support-modes></rule>

support-modes 表明该规则是否可以用于 agent 模式和 / 或静态分析其中静态分析也就是 class 模式,能够用于命令行和 Maven 插件中。关于翻译资源的打包是通过 result-code 属性实现的,在本例中,也就是 _JDK_INTERNAL_,它会映射为emt4j-common/src/main/resources/default/i18n目录中的 JDK_INTERNAL.propertiesJDK_INTERNAL_zh.properties 翻译文件。

EMT4J 会扫描应用的中的包和类,比如 _emt4j-common/src/main/resources/default/rule/8to11/data/ 目录中 _class-package-file jdk_internals.cfg 文件所定义的 sun.nio sun.reflect

实际的规则类型reference-class位于emt4j-common/src/main/java/org/eclipse/emt4j/common/rule/impl
目录中,因为 JDK 内部规则中,support-modes 的值为 agent class

@RuleImpl(type = "reference-class")public class ReferenceClassRule extends ExecutableRule {

现有的规则可以提供灵感,以便于按照 README 文件所定义的说明添加自定义规则。

原文链接:

Eclipse Migration Toolkit for Java (EMT4J) Simplifies Upgrading Java Applications(https://www.infoq.com/news/2022/12/eclipse-migration-toolkit-java/)

相关阅读:

GraalVM Java 编译器将于 2023 年加入,与 OpenJDK 的发布节奏和流程保持一致(https://www.infoq.cn/article/XOzIWQtI1qUdtX7g0Ej3)

Java 近期新闻:Ideal Graph Visualizer 开源、TomEE MicroProfile 5.0 认证(https://www.infoq.cn/article/vrFf9KauwxZ4bqWr454P)

声明:本文为 InfoQ 翻译,未经许可禁止转载。

点击底部阅读原文访问 InfoQ 官网,获取更多精彩内容!

今日好文推荐

Cloud IDE 是不是一个伪命题

阿里辟谣海外建全球总部;科技巨头加速裁员,商学教授直呼企业管理层愚蠢;谷歌Fuchsia OS部门遭遇重大打击 | Q资讯

副业搞得好、赚钱没烦恼:新春程序员寻找“副业”灵感指南

一个科技新时代开启,硅谷五巨头将何去何从

相关推荐

  • 汇总了近一年高频考点,这份Java资料通用性极强 | 极客时间
  • 字节跳动、阿里、小红书、华为如何实践可观测技术,实现研发增效?| ArchSummit
  • Web 3D 圈摸爬滚打十多年的老兵热血自述:立志做中国跨时代 Web 渲染引擎
  • 数百程序员专门教AI写代码、40个bug能修复31个,“取代程序员”这次要成真了?
  • Service Mesh:影响Kubernetes使用成本的双刃剑
  • 理想L9路边自燃起火、俄罗斯科技巨头Yandex被前员工泄露44.7G源码、百度或将推出类ChatGPT聊天机器人 | T资讯
  • 2023归零 重启 加速
  • 用户破亿!编程届当之无愧的神!
  • 如何成为世界级软件公司
  • 被 Google 裁掉的 Golden 12K:开源开发者成重灾区,61 岁再求职!
  • 用Python制作空间数据可视化
  • 胡鑫宇遗体找到!衣服破烂,口袋有钱:5大疑点是破案关键…
  • 海澜之家一折起清仓,羽绒服99秒,随时关闭,速抢。
  • 《满江红》破30亿!这个不输西安,被林徽因疯狂表白的老城,终于藏不住了...
  • 14.3k star,这是我见过最强的第三方登录工具库!!
  • 学会了海外抖音才发现:靠副业生活,真的不难!
  • 百度自动驾驶开始发力,集度汽车亮相广州车展
  • 我是,地地道道农民的孩子。。。
  • 一个45岁的人,送给你33句话
  • ChatGPT被超越了?OpenAI核心成员出走,打造Claude模型