写点什么

修剪 Java EE

  • 2009-04-15
  • 本文字数:1411 字

    阅读完需:约 5 分钟

Java EE 平台成功的一个重要原因就是其广泛的覆盖面,但其涵盖的众多 API 和技术也是广大开发者和厂商所面临的一个难题。对于想要构建 Java EE 应用服务器的新厂商来说,整个规范使其很难介入该领域;而对于 Java EE 新手来说,为数众多的 API 和缩写词也使其茫茫然不知所措。这也是导致 Java EE 如此复杂的一个重要原因,同时一些新手会觉得 Java EE 并不适合开发简单的系统,比如基本的 CRUD Web 应用,他们总觉得 Java EE 是用来开发复杂系统的。鉴于此,Java EE 6 的一个目标就是通过 3 种不同的技术来解决这些问题——配置(profile)修剪(pruning)及扩展(extensibility)。

Profile 可以是 Java EE 平台技术的一部分,也可以是额外的 JCP 技术(并不属于基础的 Java EE 平台),抑或两者兼而有之。它们能给厂商带来很多好处,因为其可以降低厂商开发 Java EE 兼容产品的门槛,同时对 Java EE 平台新手也能起到帮助作用。随着 Profile 概念的逐步规范化,Java EE 引入了第一个 Java EE profile——Web Profile,InfoQ之前的文章对此进行过详细的报道。

与此同时,Java EE 6 API 的移除工作也被提到了议事日程,所谓API 移除,意即对于厂商和开发者来说,这些API 的重要程度相对比较低,我们称其为修剪。该过程由几个步骤组成:首先在发布包中将其声明为候选者,同时在Javadoc 中也将其标识出来;然后根据社区的反馈来决定是否在下一个发布中将其放到可选组件中。

对Java EE 6 早期草案的审阅提出了两个修剪项。第一个是JAX-RPC[即 JSR 101 ,Java APIs for XML-Based RPC],它定义了通过 RPC 来访问 SOAP web services 的客户端 API,同时也定义了实现 web service 端点的技术。JAX-RPC 存在很多局限性,最明显的就是 JAX-RPC 服务端点和处理器既不支持 web service 注解,也不支持注入。随着 Java EE 5 的发布,其 API 已经被 JAX-WS 所替代。第二个是 JAXR[即 JSR 93 ,Java API for XML Registries],它提供了一种标准的方式来访问不同类型的 XML Registry 以进行绑定、部署及探测 web service,同时还包含了对 ebXML Registry 和 UDDI Registry v2.0 规范的绑定。尽管 JAXR 的替代者尚未出现,但其使用上却存在着很多限制。

对 Java EE 6 公开草案的审阅又增加了两个 API 修剪项。已经被 Java Persistence API[以前作为 JSR 220 ,Enterprise JavaBeans 3.0 的一部分] 成功取代的 EJB 2.x Container Managed Persistence 以及 Java EE Application Deployment[ JSR 88 ],后者定义了部署工具的运行环境和 Java EE 应用服务器所提供的插件组件之间的接口。理论上凭借该 API,我们可以使用相同的部署工具将任何 Java EE 应用部署到任何 Java EE 兼容的环境中,但遗憾的是,厂商对其的支持实在是太弱了。

与 JSR 88 类似,专家组也在考虑移除 Java EE Management[ JSR 77 ],它向管理工具提供了 API 以查询 Java EE 应用服务器的当前状态、部署的应用等等。使用这些 API 构建的服务器管理工具可以跨厂商运行,这样就可以切换应用服务器而无需改变管理工具和过程,还可以管理多个 Java EE 服务器所构成的网络,而网络中可以包含多个厂商实现。与 JSR-88 一样,厂商对该 API 的支持力度也很弱。

随着 API 的裁剪,专家组希望减少那些使用量少的 API,转而提供更多的扩展点。我们应该可以使用这些接口和插件点轻松创建平台的扩展技术,同时保持很好的集成性,这么做也会使规范本身重获新生。

查看英文原文: Pruning The Deadwood from Java EE

2009-04-15 01:153248
用户头像

发布了 88 篇内容, 共 273.5 次阅读, 收获喜欢 9 次。

关注

评论

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

即时通讯技术文集(第46期):微信、QQ技术精华合集(Part3) [共15篇]

JackJiang

网络编程 即时通讯 IM

基于 HarmonyOS NEXT 的跨设备分布式文件传输系统

最新动态

WebGL 开发项目的流程

北京木奇移动技术有限公司

软件外包公司 数字孪生开发 webgl开发

分析流程自动优化!Fabarta个人专属智能体「数据分析」新功能介绍

Fabarta

人工智能 个人专属智能体

时间轴相册照片直播小程序系统详解

微擎应用市场

后台提醒与代理提醒:HarmonyOS NEXT的智能提醒管理

最新动态

设计一个可复用的 ArkWeb 基础组件架构

最新动态

前端热更新驱动下的中国互联网开发范式重构

xuyinyin

大数据-87 Spark 实现圆周率计算与共同好友分析:Scala 实战案例

武子康

Java 大数据 flink spark 分布式

数造科技助力广州白云智慧城管项目斩获双奖,赋能城市精“绣”“智”理新篇章

数造万象

智慧城市 政务 资讯 大数据、 人工智能、

中秋有奖问答系统介绍

微擎应用市场

快微音频课程高级版小程序系统详解

微擎应用市场

HarmonyOS NEXT后台任务开发入门:背景与基本任务类型

最新动态

MyEMS 开源能源管理系统:驱动能源高效利用的开源创新引擎

开源能源管理系统

开源 开源能源管理系统

WebGL 开发数字孪生的技术难点

北京木奇移动技术有限公司

数字孪生 软件外包公司 webgl开发

九宫格切图-创意分享新风尚

最新动态

探索ArkWeb的奥秘:架构了解与生命周期管理

最新动态

三维模型爆炸:拆解复杂结构的可视化神器

在路上

cad

Supersonic from Unity:关注手游 D30 留存,把“新玩家”变“老朋友”

极客天地

三维模型爆炸是什么?如何实现三维爆炸?

在路上

cad cad看图 CAD看图王

天猫商品详情API 数据解析(附代码)

tbapi

天猫商品详情接口 天猫API 天猫商品数据采集 天猫数据采集

轻松上手-识图文字朗读

最新动态

恒泰证券领导一行到访非凸科技,共筑数智交易服务新生态

非凸科技

大屏幕摇号应用:现场随机选择工具详解

微擎应用市场

AI智能体开发的技术方案

北京木奇移动技术有限公司

AI智能体 软件外包公司 AI技术应用

MyEMS 开源能源管理系统:打造智能高效的能源管控新模式

开源能源管理系统

开源 开源能源管理系统

MyEMS 开源能源管理系统:开启能源管理新视界

开源能源管理系统

开源 开源能源管理系统

学会 Java 异常处理,其实没你想的那么难

秃头小帅oi

火山引擎多模态数据湖落地深势科技,提升科研数据处理效能

字节跳动数据平台

IT 预算突围战:破解VMware成本困局,国产超融合给出“最优解”

智驱前线

鸿蒙NEXT之数据同步艺术之一:方舟数据管理揭秘

最新动态

修剪Java EE_Java_Charles Humble_InfoQ精选文章