Java理论与实践: 让J2EE脱离容器[Java编程]
本文“Java理论与实践: 让J2EE脱离容器[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
在大大都情形下,Java 利用程序要末是 J2EE 利用程序、要末是 J2SE 利用 程序,并且在这一点上是泾渭清楚的.J2EE 利用程序需求 J2EE 容器的服务, 容器要实现一长串的 J2EE API,包含 Enterprise JavaBean (EJB)、JTA、JNDI 、JMS、JCA 和 JMX.J2EE API 计划为协同工作;毕竟,J2EE 计划是从多年来 数百人开辟企业利用程序的经验中提取出的大众需求.像全部框架一样,J2EE API 的主要目的是“不重新创造轮子”.
有一些 API 属于 J2EE 标准的一部份,但是可以很简单地在 J2SE 利用程序 中利用,如 JDBC、JSP 和 servlet,但是关于大大都 J2EE API,J2EE 是一个 要末是要末不是的命题--大大都 J2EE API 需求全功效的 J2EE 容器.不过,有 一些服务器利用程序开辟为 J2SE 利用程序而非 J2EE 利用程序,这普通都有很 好的来由.为什么这些利用程序的开辟人员必须重新创造轮子呢?J2EE 中能否 有部份内容可以简单地被 J2SE 利用程序借用来供应一样的长处呢?什么组件可 以同时用于 J2EE 和 J2SE 利用程序的组件呢?
疏松耦合
J2EE 的一个主要计划原理是 J2EE 利用程序可以疏松地耦合--用组件组装, 在组装大概布置利用程序时而不是在组件开辟时定义大概改变这些组件的彼此连 接.J2EE 组件利用 JNDI 彼此查找和查找所需求的资源,如 JDBC 和 JMS 衔接 .JMS 这样的技术鼓舞疏松耦合,答应机动地为工作流程建模、简单分配处理任 务、可伸缩性和容错性.很多 J2SE 服务器利用程序也可以从这些技术和原理中 受益.
像 JDBC、JMS 和 JNDI 这样的 API 基本上是“中间件”--它们作为利用程 序与差别的服务供应者之间的统一接口.几近每一个数据库服务器都有 JDBC 驱 动程序,有大量的免费数据库服务器,所以几近每一个但愿操纵数据库的 Java 利用程序都可以简单地做到这一点.不过,关于 JMS 就不是这样了.消息行列 服务器远没有数据库这样常见,分外是在小型商店中.但是有大量的利用程序可 以通过利用消息行列而极大地受益.
Somnifugi JMS
消息行列是一个功效强盛的典范,它用于构建结实的、机动的、疏松耦合的 、可伸缩的利用程序.有一些商业消息行列产品,如 WebSphere MQ、Sonic、 Fiorano、JBossMQ 和 SpiritWave.就像 JDBC 关于数据库一样,JMS 是消息的 中间件--它使得利用程序可以通过统一的接口拜候差别的消息行列产品,这个接 口供应了像 Connection 、 Topic 和 Message 这样的抽象.
很多 J2SE 利用程序利用某种情势的消息行列,但是不利用 JMS--而是利用 线程池、工作行列、任务管理器等.AWT 和 Swing 框架利用消息(事件)在模 型与视图层之间通信,JavaBean 组件操纵监听器支持一种基于主题的消息.消 息行列供应了很多构造上的长处--它固有的疏松耦合有利于采取机动的、基于组 件的办法,并供应了有助于简化计划和削减互连的自然抽象边界.一个附带的好 处是,MQ 典范使得分布式的、可伸缩的和容错的计划变得更简单了,因为消息 生产者和利用者不一定需求运行在同一 JVM 中,大大都生产者/利用者任务的本 性是答应并发处理的.
J2SE 服务器利用程序的开辟人员常常开辟他们自己的消息层,大概从零开始 ,大概以 util.concurrent 这样的库为底子构建.普通这么做的来由是:
MQ 服务器是高贵的和重量级的,并且由于我们不需求像长期性、分布式、事 务和考证这样更重量级的功效,构建自己内存中的消息层,只供应所需求的功效 会更简单.
固然这在普通情形下是精确的,但是利用程序需求普通会随着时间而增添, 在开始时不需求的一些消息功效在今后大概会变得更重要了.
面向消息的利用程序的开辟人员在开辟历程的早期就必须做出挑选--挑选一 个商业消息产品,大概构建自己的更便宜的、更轻量级的办理筹划.Somnifugi JMS 包结合了这两种方法--一个基于高性能的 util.concurrent 库的非长期内 存中消息行列服务,和一个符合 JMS API 的接口.与传统 JMS 供应者相对比, Somnifugi 是相当轻量级的,不管是功效上还是性能上.它只限于在一个 JVM 中利用(固然可以撤消这种限制),并贫乏长期性、事件和考证功效.另一方面 ,它分外快--它比传统 JMS 实现快得多,以至于可以在因性能缘由大概无法使 用消息的地方利用它.为了表明 Somnifugi 到底有多轻量级,在它的分发中包 含了几个用 JMS 主题代替 Swing/JavaBean 事件框架的例子.
增添的机动性
Somnifugi 还供应了另一项重要的长处:目前可以开辟利用 JMS 接口的组件 ,然后在布置利用程序时决意是利用更快的、内存中的 Somnifugi 供应者还是 更重量级的、但是更坚固的供应者,如 WebSphere MQ.可以将这种挑选推迟到 布置时的好处非常宏大--分外是因为需求大概会在项目的开辟历程中改变时--并 供应了代码重用的机会,关于自已开辟的消息层来说这是不太大概做到的.
以上是“Java理论与实践: 让J2EE脱离容器[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |