首页 Java java教程 Jakarta EE 对开发人员需求的响应效果如何?

Jakarta EE 对开发人员需求的响应效果如何?

Sep 27, 2024 am 06:11 AM

How well did Jakarta EE respond to the needs of developers?

交叉发布在 Ed Burns 博客上。

执行摘要

Jakarta 指导委员会特许了 Jakarta 平台项目,其目标是在 EE 11 的开发中纳入开发人员的反馈。这篇博文回顾了该平台项目的性能,并以 4 分制的方式授予 GPA 3.43 的成绩目标。

介绍

我很荣幸也很荣幸能够帮助交付 Jakarta EE 的下一个版本。几十年来,我在 J2EE/Java EE/Jakarta EE 中担任过许多角色:实施者、规范负责人、倡导者、作者、测试人员等等。然而,我目前的角色对我来说是一个新的发布协调员。

在此职位上,我(与 Arjan Tijms 一起)共同领导 Jakarta 平台项目,该项目负责交付完成的 Jakarta EE 规范(和组件规范)、相应的 TCK,并至少批准兼容的实现所有规格。重要的是,不需要有一个单一的整体实现同时满足所有组件 TCK,但必须有一个通过平台 TCK 的单一整体实现。

本着二十多年前我有幸开始的透明精神,这篇博文探讨了 Jakarta 平台项目在 EE 11 期间在实现指导委员会为平台项目设定的目标之一方面的表现:纳入开发者反馈。

承诺不足和交付过多

制度记忆是人类群体从错误中学习并避免重蹈覆辙的方式。根据这个定义,我希望我们都能同意机构记忆很重要并且值得保存。因为软件是可执行的知识,所以长期运行的开源软件项目是一种特殊的机构记忆。一个由长期运行的开源项目组成的长期运行的生态系统的项目几乎是特殊的顶峰。考虑到所有这些特殊性,纳入开发者反馈意味着什么?

当犯错误的可能成本包含在单个项目中时,显示对开发人员反馈的响应要容易得多。鉴于可能的高成本,Jakarta EE 11 平台项目故意保持低调,以实现纳入开发人员反馈的目标。这是我们对“承诺不足、交付过多”这一久经考验的策略的实施。

在 Jakarta EE 11 发布之前,我们对 Jakarta EE 11 的要求进行了公开社区讨论,并将其记录在本 Jakarta EE 11 讨论文档中。让我们回顾一下我们收到的社区意见(主要是开发人员驱动的),看看我们在 EE11 中的表现如何。

承诺不足

  • 雅加达数据

  • 雅加达 NoSQL

  • 采用 Java SE 11、17、21 新功能和重大更改

  • 虚拟线程

  • TCK 重构

  • 以 CDI 为中心

    • CDI 取代托管 Bean
    • CDI 取代 EJB
  • 解决冗余 HTTP 堆栈:Servlet 和 REST

  • MicroProfile 和 Jakarta 对齐

  • CORS 支持

  • 雅加达配置

  • 让从一个供应商迁移到另一个供应商变得更容易

混合发货

我将把交付分为四类:超额交付、已交付、部分交付、未交付。

超额交付

  • Jakarta Persistence - 编程配置而不是 persistence.xml 以及更多 Gavin King 博客文章
  • Jakarta Security - 动态选择身份验证机制 security-311

发表

  • 雅加达数据

    • 是的,这个新规范已出现在平台中。
  • 采用 Java SE 11、17、21 新功能和重大更改。

    • 是的,有许多规范利用了 11 - 21 的新语言功能。
  • TCK 重构(我们将交付此内容。我们正在为其保留发布版本)。

    • Jakarta EE 平台 TCK 是一个重要的软件组件,可实现数十年规模的 IT 投资稳定性价值主张。由于缺乏维护投资,TCK 的软件一直在积累技术债务。在 Jakarta EE 11 中,我们使 TCK 与最先进的测试工具保持同步。随着 Jakarta EE 平台的发展,这项投资将实现更好的兼容性测试,并降低添加更多测试的障碍。
  • API 灵活性,即不再需要 Umbrella JAR。

    • 不再有类似“我必须等待 Jakarta EE xx”才能拥有此功能的问题吗?
    • Jakarta EE Platform API 现在只是默认 API 的集合。
    • 个别规格可以由用户根据自己的意愿排除或升级,
    • 也可以添加新规格。
    • 这使得 Jakarta EE 平台像 Spring Boot 一样灵活,但应用程序中没有实现包袱,两全其美!

有点交付

  • 虚拟线程

    • 并发规范严格指定了注释属性,要求实现利用虚拟线程(如果虚拟线程在运行时可用)。如果您在 Java 21 或更高版本上运行,则在使用注释属性时会获得虚拟线程。如果你在 17 号跑步,你就不会。
  • 以 CDI 为中心

    • CDI 取代托管 Bean。

      • 我们做到了
        • 删除@ManagedBean注释。
        • 将 CDI 的“集成”部分从 CDI 规范移至平台规范。
        • Jakarta Concurrency 在 @Asynchronous 注释中添加了调度,以替换 EJB 并发上的 @Scheduled 注释 - 271
        • 将并发资源注入 CDI bean,而不是在 EJB 并发中使用 @Resource-348。
        • 删除了 Jakarta REST 中的托管 Bean 支持。
        • 持久化中持久化单元的限定符 - 允许以 CDI 惯用方式注入持久化上下文。
  • Java 新功能

    • 在 Jakarta Persistence 中记录为可嵌入项和 ID。
    • 用表达语言记录。
    • Validation(以前的 Bean Validation)validation-275 中的记录。
    • 并发中的 Flow API concurreny-368。
  • MicroProfile 和 Jakarta 对齐

    • 我们做到了
      • 创建 Jakarta Security MicroProfile 安全桥规范。

没有交付

  • 雅加达 NoSQL

    • 这在 EE 11 开发周期开始时没有通过投票。在我看来,原因是非技术性的,因此可以在 EE 12 中解决。
  • 解决冗余 HTTP 堆栈:Servlet 和 REST

    • 这是一个非常大的。在我看来,需要一个主要供应商支持这个想法,并投入大量资源来实现它,可能会向竞争对手捐赠工作,这样他们也可以这样做。
  • CORS 支持

    • 这个甚至没有出现在我的雷达上。
  • 雅加达配置

    • 这个似乎陷入了“MicroProfile 配置足够好”的困境,因此陷入了困境。我认为我们必须说服 MicroProfile 项目允许其从 MicroProfile 转移到 Jakarta EE Core Profile 规范。
  • 让从一个供应商迁移到另一个供应商变得更容易

    • 这与每个供应商的商业利益是对立的,所以我认为这一点不会受到太多关注。

概括

让我们定量一下。对于Underpromise列表中的每一项,我都会给我们一个字母等级。 A 表示超额交付或交付,B 表示部分交付,D 表示未交付。

Feedback to incorporate Grade
Jakarta Data A
Jakarta NoSQL D
Adopt Java SE 11, 17, 21 new features and Breaking Changes A
Virtual Threads A
TCK Refactoring A
CDI Centric A
Resolve redundant HTTP stacks: Servlet and REST D
MicroProfile and Jakarta Alignment B
CORS support D
Jakarta Config D
Make it easier to migrate from one vendor to another D

通过这份清单,我们的 GPA 只达到了 2.54。不太好。如果我们从列表中删除我认为不现实的开发人员反馈请求(CORS、冗余 HTTP 堆栈、Jakarta 配置、使从一个供应商迁移到另一个供应商变得更容易),我们会得到更好的分数:3.43。不错,但我们还有成长的空间。

以上是Jakarta EE 对开发人员需求的响应效果如何?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1673
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
公司安全软件导致应用无法运行?如何排查和解决? 公司安全软件导致应用无法运行?如何排查和解决? Apr 19, 2025 pm 04:51 PM

公司安全软件导致部分应用无法正常运行的排查与解决方法许多公司为了保障内部网络安全,会部署安全软件。...

如何将姓名转换为数字以实现排序并保持群组中的一致性? 如何将姓名转换为数字以实现排序并保持群组中的一致性? Apr 19, 2025 pm 11:30 PM

将姓名转换为数字以实现排序的解决方案在许多应用场景中,用户可能需要在群组中进行排序,尤其是在一个用...

如何使用MapStruct简化系统对接中的字段映射问题? 如何使用MapStruct简化系统对接中的字段映射问题? Apr 19, 2025 pm 06:21 PM

系统对接中的字段映射处理在进行系统对接时,常常会遇到一个棘手的问题:如何将A系统的接口字段有效地映�...

如何优雅地获取实体类变量名构建数据库查询条件? 如何优雅地获取实体类变量名构建数据库查询条件? Apr 19, 2025 pm 11:42 PM

在使用MyBatis-Plus或其他ORM框架进行数据库操作时,经常需要根据实体类的属性名构造查询条件。如果每次都手动...

IntelliJ IDEA是如何在不输出日志的情况下识别Spring Boot项目的端口号的? IntelliJ IDEA是如何在不输出日志的情况下识别Spring Boot项目的端口号的? Apr 19, 2025 pm 11:45 PM

在使用IntelliJIDEAUltimate版本启动Spring...

Java对象如何安全地转换为数组? Java对象如何安全地转换为数组? Apr 19, 2025 pm 11:33 PM

Java对象与数组的转换:深入探讨强制类型转换的风险与正确方法很多Java初学者会遇到将一个对象转换成数组的�...

电商平台SKU和SPU数据库设计:如何兼顾用户自定义属性和无属性商品? 电商平台SKU和SPU数据库设计:如何兼顾用户自定义属性和无属性商品? Apr 19, 2025 pm 11:27 PM

电商平台SKU和SPU表设计详解本文将探讨电商平台中SKU和SPU的数据库设计问题,特别是如何处理用户自定义销售属...

如何利用Redis缓存方案高效实现产品排行榜列表的需求? 如何利用Redis缓存方案高效实现产品排行榜列表的需求? Apr 19, 2025 pm 11:36 PM

Redis缓存方案如何实现产品排行榜列表的需求?在开发过程中,我们常常需要处理排行榜的需求,例如展示一个�...

See all articles