`
阅读更多

EJBsun的服务器端组件模型,最大的用处是部署分布式应用程序当然,还有许多方式可以实现分布式应用,类似微软的.net技术。凭借java跨平台的优势,用EJB技术部署的分布式系统可以不限于特定的平台。EJB (Enterprise JavaBean)J2EE的一部分,定义了一个用于开发基于组件的企业多重应用程序的标准。其特点包括网络服务支持和核心开发工具(SDK)。 在J2EE里,Enterprise Java Beans(EJB)称为Java 企业Bean,是Java的核心代码,分别是会话BeanSession Bean),实体BeanEntity Bean)和消息驱动BeanMessageDriven Bean)。

EJB简介

  1.Session Bean用于实现业务逻辑,它可以是有状态的,也可以是无状态的。每当客户端请求时,容器就会选择一个Session

  

EJB

Bean来为客户端服务。Session Bean可以直接访问数据库,但更多时候,它会通过Entity Bean实现数据访问。

  2.Entity Bean是域模型对象,用于实现O/R映射,负责将数据库中的表记录映射为内存中的Entity对象,事实上,创建一个Entity Bean对象相当于新建一条记录,删除一个Entity Bean会同时从数据库中删除对应记录,修改一个Entity Bean时,容器会自动将Entity Bean的状态和数据库同步。

  3.MessageDriven BeanEJB2.0中引入的新的企业Bean,它基于JMS消息,只能接收客户端发送的JMS消息然后处理。MDB实际上是一个异步的无状态Session Bean,客户端调用MDB后无需等待,立刻返回,MDB将异步处理客户请求。这适合于需要异步处理请求的场合,比如订单处理,这样就能避免客户端长时间的等待一个方法调用直到返回结果。

  EJB实际上是SUNJ2EE中的一套规范,并且规定了一系列的API用来实现把EJB概念转换成EJB产品.EJBBEANS,BEANS是什么概念,那就是得有一个容纳她,让她可劲造腾的地方,就是得有容器.EJB必须生存在EJB容器中.这个容器可是功能强大之极!她首先要包装你BEAN,EJB的客户程序实际上从来就不和你编写的EJB直接打交道,他们之间是通过HOME/REMOTE接口来发生关系的.它负责你的BEAN的所有的吃喝拉撒睡,比如BEAN的持续化,安全性,事务管理...

.什么是 EJB?

  一个技术规范:EJB 从技术上而言不是一种"产品"

  

EJB

EJB 是一种标准描述了构建应用组件要解决的:

  可扩展 (Scalable)

  分布式 (Distributed)

  事务处理 (Transactional)

  数据存储 (Persistent)

  安全性 (Secure)

.Sun EJB 的期望

  提供一个标准的分布的、基于 OO 的组件架构

  屏蔽复杂的系统级功能需求

  Write once, run anywhere

  与非 Java 应用之间的互操作能力

  兼容CORBA 标准

.为什么选择 EJB?

  EJB 服务器完成"繁杂"的工作:应用开发人员关注于业务逻辑的实现而不是底层的实现机制(类似于 4GL 语言设计的目标)

  支持事务处理

  多个业务操作同时成功,或全部失败

  可以通过在代码外的描述来定义事务处理级别

  

EJB

可扩展性

  EJB 可以根据您应用的增长而扩展

  EJB 服务器往往还提供了负载均衡和

  安全性:由 EJB 服务器提供资源的访问权限控制

.EJB 架构

  为了满足架构的目标,规范中描述了

  服务器 (Server)

  容器 (Container)

  类 (Class) 和实例 (Instance)

  Home Remote 接口

  客户端 (Client)

. 简化的编程模型

  关注于业务逻辑实现:EJB 负责生命周期 (lifecycle), 数据存储 (persistence), 事务处理语义 (transactional semantic), 安全(security), ...

  通用的编程模型:各种服务的高层 API

  Java 是其编程语言

  EJB( 业务逻辑代码 ) 表示了与特定商业领域(例如银行、零售等行业)相适应的逻辑。它由

  运行在业务逻辑层的 enterprise bean 处理。一个 enterprise bean 可以从客户端接受数据,对

  它进行处理,并将其发送到企业信息系统层以作存储;同时它也可以从存储器获取数据,

  处理后将其发送到客户端应用程序。

  有三种类型的 enterprise beanssession beansentity beans message-driven beans

  Session bean 描述了与客户端的一个短暂的会话。当客户端的执行完成后,session bean

  它的数据都将消失;与之相对应的是一个 entity bean 描述了存储在数据库表中的一行持久

  稳固的数据,如果客户端终止或者服务结束,底层的服务会负责 entity bean 数据的存储。

  Message-driven bean 结合了 session bean Java 信息服务(JMS)信息监听者的功能,它允

  许一个商业组件异步地接受 JMS 消息。

编辑本段

EJB3.0的介绍

  由于EJB2.0的复杂性,在SpringHibernate等轻量级框架出现后,大量的用户转向了,在大家的呼声中,EJB3.0规范终于发布了。

  

EJB

期待已久的EJB3.0规范在终于发布了。在本文中将对新的规范进行一个概要性的介绍,包括新增的元数据支持,EJBQL的修改,实体Bean模型访问 bean上下文的新方法和运行时环境等等。作者还讨论了EJB在未来要作出的调整以及EJB3.0与其他开发规范之间的关系。

开始

  无论如何由于EJB的复杂性使之在J2EE架构中的表现一直不是很好。EJB大概是J2EE架构中唯一一个没有兑现其能够简单开发并提高生产力的组件EJB3.0规范正尝试在这方面作出努力以减轻其开发的复杂性。EJB3.0减轻了开发人员进行底层开发的工作量,它取消或最小化了很多(以前这些是必须实现)回调方法的实现,并且降低了实体BeanO/R映射模型的复杂性。

  在本文中,我首先会介绍EJB3.0中几个主要的改变。它对进一步深入了解EJB3.0是非常重要的。随后,我会从更高的层面来描述已经被提交到EJB3.0规范中的细节,并一个个的讲解新的规范中的改变:实体Bean,O/R映射模型,实体关系模型和EJB QL(EJB查询语言)等等。

背景

  EJB3.0中两个重要的变更分别是:使用了Java5的程序注释工具和基于HibernateO/R映射模型。

  

EJB

Java5中的元数据工具

  Java5(以前叫J2SE1.5Tiger) 中加入了一种新的程序注释工具。通过这个工具你可以自定义注释标记,通过这些自定义标记来注释字段、方法、类等等。这些注释并不会影响程序的语义,但是可以通过工具(编译时或运行时)来解释这些标记并产生附加的内容(比如部署描述文件),或者强制某些必须的运行时行为(比如EJB组件的状态特性)。注释的解析可以通过源文件的解析(比如编译器或这IDE工具)或者使用Java5中的APIs反射机制。注释只能被定义在源代码层。由于所有被提交到 EJB3.0草案中的注释标记都有一个运行时的RetentionPolicy,因此会增加类文件占用的存储空间,但这却给容器制造商和工具制造商带来了方便。

  Hibernate

  目前Hibernate非常受欢迎,它是开发源代码的Java O/R映射框架,目的是把开发人员从繁琐的数据持久化编程中解脱出来。它也有一个标准的HQL(Hibernate 查询语言)语言,你可以在新的EJB QL中看到它的影子。Hibernate在处理如数据查询、更新、连接池、事务处理、实体关系处理等方面非常简单。

概览

  在已经提交的EJB3.0规范中主要涉及两个方面的改变:

  1. 一套以注释为基础的EJB编程模型,再加上EJB2.1中定义的通过部署描述符和几个接口定义的应用程序行为。

  2. 新的实体Bean持久化模型,EJBQL也有许多重要的改变。

  还有一些有关上述的提议,比如:一个新的客户端编程模型,业务接口的使用以及实体Bean的生命周期。请注意EJB2.1编程模型(包括部署描述符和home/remote接口)仍然是有效的。新的简化模型并没有完全取代EJB2.1模型。

编辑本段

EJB注释

  EJB规范组织一个重要的目标是减轻原始代码的数量,并且他们为此给出了一个完美而简洁的办法。在

  

EJB

EJB3.0的里,任何类型的企业级 Bean只是一个加了适当注释的简单Java对象(POJO)。注释可以用于定义bean的业务接口、O/R映射信息、资源引用信息,效果与在 EJB2.1中定义部署描述符和接口是一样的。在EJB3.0中部署描述符不再是必须的了;home接口也没有了,你也不必实现业务接口(容器可以为你完成这些事情)

  比如,你可以使用@Stateless注释标记类把Java类声明为一个无状态会话bean。对于有状态会话bean来说,@Remove注释可以用来标记一个特定的方法,通过这个注释来说明在调用这个方法之后bean的实例将被清除掉。

  为了减少描述组件的说明信息,规范组织还采纳了由异常进行配置(configuration-by-exception)的手段,意思是你可以为所有的注释提供一个明确的缺省值,这样多数常规信息就可以据此推断得出。

新的持久化模型

  新的实体bean也是一个加了注释的简单Java对象(POJO)一旦它被EntityManager访问它就成为了一个持久化对象,并且成为了持久化上下文(context)的一部分。一个持久化上下文与一个事务上下文是松耦合的;严格的讲,它隐含的与一个事务会话共存。

  实体关系也是通过注释来定义的,O/R映射也是,并提供几种不同的数据库规范操作,在EJB2.1中这些

  

EJB

要通过开发人员自己的设计模式或者其它技术来完成的(比如,自增长主键策略)

  深入研究

  现在是时候详细了解EJB3.0草案了。让我们开始探讨所有EJB中四种企业级bean,并看看他们在新的规范中是什么样子。

无状态会话bean

  在EJB3.0规范中,写一个无状态会话bean(SLSB)只需要一个简单的Java文件并在类层加上@Stateless注释就可以了。这个bean可以扩展javax.ejb.SessionBean接口,但这些不是必须的。

  一个SLSB不再需要home接口,没有哪类EJB再需要它了。Bean类可以实现业务接口也可以不实现它。如果没有实现任何业务接口,业务接口会由任意public的方法产生。如果只有几个业务方法会被暴露在业务接口中,这些方法可以使用@BusinessMethod注释。缺省情况下所有产生的接口都是local(本地)接口,你也可以使用@Remote注释来声明这个接口为remote(远程)接口。

  下面的几行代码就可以定义一个HelloWorldbean了。而在EJB2.1中同样的bean至少需要两个接口,一个实现类和几个空的实现方法,再加上部署描述符。

  import javax.ejb.*;

  /**

  * A stateless session bean requesting that a remote business

  * interface be generated for it.

  */

  ;@Stateless

  ;@Remote

  public class HelloWorldBean {

  public String sayHello() {

  return "Hello World!!!";

  }

  }

有状态会话bean

  除了几个SFSB的特别说明之外,有状态会话bean(SFSB)SLSB一样精简:

  

  

EJB

一个SFSB应该有一个方法来初始化自己(EJB2.1中是通过ejbCreate()来实现的)。在EJB3.0的规范中建议这些初始化操作可以通过自定义方法完成,并把他们暴露在业务接口中。在使用这个bean之前由客户端来调用相应的初始化方法。目前规范组织就是否提供一个注释来标记某个方法用于初始化还存在争议。

  Bean的提供者可以用@Remove注释来标记任何SFSB的方法,以说明这个方法被调用之后bean的实例将被移除。同样,规范组织仍然在讨论是否要有一种机制来处理这种特殊的情况,即当这个方法出现异常的情况下bean的实例是否被移除。

  下面是对以上问题我个人的观点:

  是否应该有一个注释来标明一个方法进行初始化呢?我的观点是――应该有,这样容器就可以在调用其他方法之前至少调用一个方法来进行初始化。这不仅可以避免不必要的错误(由于没有调用初始化方法)而且可以使容器更明确的判断是否可以重用SFSB实例。我暂且把这个问题放一放,规范组织只考虑为一个方法提供一个注释来声明它是一个初始化方法。

  对于第二个问题我的观点也是肯定的。这有利于Bean的提供者合客户端程序对其进行控制。只有一个遗留的问题:那就是一旦调用这个方法失败,是否能移除这个bean 的实例?答案是不能,但是它将会在会话结束的时候被移除。

消息驱动Bean

  消息驱动Bean是唯一一种必须实现一个业务接口的Bean。这个接口指出bean支持的是哪一种消息系统。对于以JMS为基础的MDB来说,这个接口是javax.jms.MessageListener。注意MDB业务接口不是一个真正意义上的业务接口,它只是一个消息接口。

实体Bean

  实体Bean使用@Entity注释来标记,所有实体bean中的属性/字段不必使用@Transient注释来标记。实体bean的持久化字段可以通过JavaBean-style机制或者声明为public/protected字段来实现。

  实体bean可以使用助手类来描述其状态,但是这些类的实例并没有持久化唯一性(persistent identity)的特性(即,唯一标识这个bean的字段等),实际上这些助手类与他们的实体bean实例是紧密结合的;并且这些对象还是以非共享方式来访问实体对象的。

实体关联

  EJB3.0同时支持Bean之间双向的合单向的关联,它们可以是一对一、一对多、多对一或者是多对多的关联。然而双向关联的两端还要分为自身端 (owning side)和对方端(inverse side)不同的端。自身端负责向数据库通告关联的变更。对于多对多的关联自身端必须明确的声明。实际上对方端通过isInverse=true进行注释 (由此自身端就不必说明了而是由另一段推断出)。看来上面的描述,规范组织还能说让EJB变的简单了吗?

O/R映射

  EJB3.0中的O/R映射模型也有了重要的改变,它从原来的abstract-persistence-schema-based变成了现

  

EJB

在的Hibernate-inspired模式。尽管目前规范组织还在就此进行讨论但是一个明确的模型将会出现在下一个版本的草案中。

  举例来说,O/R映射模型将通过bean类中的注释来声明。而且此方法还会指出对应的具体表和字段。O/R映射模型提供了一套自有的SQL; 而且除了提供一些基本的SQL外还支持某些高层开发的功能。比如,有一个通过@Column注释声明的字段columnDefinition,那么可以写这 样的SQL:columnDefinition="BLOB NOT NULL"

客户端程序模型

  一个EJB客户端可以通过@Inject注释以一种注入的方式获得一个bean的业务接口引用。你也可以使用另一个注释 @javax.ejb.EJBContext.lookup()来完成上面的操作,但是规范中没有告诉我们一个普通的Java客户端怎样获得一个Bean 的实例,因为这个普通的Java客户端是运行在一个客户端容器中,它无法访问@javax.ejb.EJBContex对象。现在还有另外一种机制来完成上面的工作那就是使用一个超级上下文环境对象:@javax.ejb.Context()。但是规范中没有指出该如何在客户端中使用这个对象。

EJB QL

  EJB QL可以通过@NamedQuery来注释。这个注释有两个成员属性分别是namequeryString.一旦定义了这些属性,就可以通过 EntityManager.createNamedQuery(name)来指向这个查询。你也可以创建一个标准的JDBC风格的查询并使用 EntityManager.createQuery(ejbqlString)EntityManager.createNativeQuery (nativeSqlString)(这个方法用于执行一个本地查询)来执行查询。

  EJB QL有两个地方可以定义其参数。javax.ejb.Query接口提供了定义参数、指向查询、更新数据等等方法。下面是一个EJBQL指向查询的例子:

  查看复制到剪切板打印

  . ..

  ;@NamedQuery(

  name="findAllCustomersWithName",

  queryString="SELECT c FROM Customer c WHERE c name LIKE :custName"

  )

  .. ..

  ;@Inject public EntityManager em;

  customers = em.createNamedQuery("findAllCustomersWithName")

  .setParameter("custName", "Smith")

  .listResults();

  下面列出了一些EJB QL的增强特性:

  支持批量更新和删除。

  直接支持内连接和外连接。FETCH JOIN运行你指出关联的实体,Order可以指定只查询某个字段。

  查询语句可以返回一个以上的结果值。实际上,你可以返回一个依赖的类比如下面这样:

  SELECT new CustomerDetails(c id, c.status, o.count)

  FROM Customer c JOIN c.orders o

  WHERE o.count > 100 l 支持group by having

支持where子句的嵌套子查询

  在提交的EJB3.0草案中,EJB QL与标准SQL非常的接近。实际上规范中甚至直接支持本地的SQL(就像我们上面提到的那样)这一点对某些程序员来说也许有些不是很清楚,我们将在下面进行更详细的讲解。

多样性

  方法许可(Method permissions)可以通过@MethodPermissions@Unchecked注释来声明;同样的,事务属性也可以通过 @TransactionAttribute注释来声明。规范中仍然保留资源引用和资源环境引用。这些一样可以通过注释来声明,但是有一些细微的差别。比如,上下文(context)环境要通过注入工具控制。容器根据bean对外部环境引用自动初始化一个适当的已经声明的实例变量。比如,你可以象下面这样获得一个数据源(DataSource):

  ;@Resource(name="myDataSource") //Type is inferred from variable

  public DataSource customerDB;

  在上面的例子中如果你不指定引用资源的名称(name)那么其中的customerDB会被认为是默认值。当所有的引用属性都可得到时候@Injec注释就可以这样写:

查看复制到剪切板打印

<
分享到:
评论

相关推荐

    EJB 知识与运行环境设置(笔记)

    EJB 知识与运行环境设置(笔记),这是我在培训机构的培训笔记,绝对内部资料,写的很详细,很容易看懂!!

    EJB 知识笔记 比较实用

    比较详细的EJB笔记,介绍了EJB的一系列知识,包括EJB的概念、发展、编程方式与步骤,还主要介绍了JPA的编程方式

    EJB3.0知识点归纳

    这是一个ejb知识点的归纳,如果你有项目开发经验,本知识点就能让你上路,尚可以作为开发手册使用.

    深入浅出EJB

    你要构建应用,要对付最后期限,如果通过考试之后第二天早上就把你学过的EJB知识忘得一干二净,你肯定会受不了。 我们会看着你稳稳当当地通过考试,而且会帮你在实际中使用EJB。你会深入地了解EJB体系结构、会话、...

    EJB3中MessageDrivenBean知识

    个人总结的EJB3中MessageDrivenBean的相关知识,现分享与大家,欢迎下载。

    EJB基础知识2---EJB资料

    EJB资料,EJB基础知识。大家看看吧!想搞好java开发就快来看看吧!

    EJB 3.0消息驱动Bean(p-to-p and Topic)

    许多初学者拜求的EJB知识点: @MessageDriven( activationConfig ={ @ActivationConfigProperty(propertyName="destinationType",propertyValue="javax.jms.Topic"), @ActivationConfigProperty(property...

    ejb3.0实例教程

    作者对 EJB3.0 接触的时间很短,所以一些新的概念和知识理解也难免有误,有些概念和语义把握的不是很准, 希望在这方面有经验和了解的朋友批评指正,欢迎多提意见。 因为 JBOSS EJB3.0 产品常未成熟,本教程随着新...

    精通EJB第三版

    本书是关于EJB 2.1的经典书籍,是EJB开发者必备的参考书。全书共分为3篇。第1篇对EJB编程基础进行...具体内容包括开发各种EJB组件的基础知识(结合开发实例)、组件生命周期的详细阐述;第3篇是本书最为令人兴奋的一部分。

    EJB 3.0从入门到精通

    本书面向EJB 3.0的实际应用开发,通过大量的实例,循序渐进地为读者介绍了有关EJB 3.0开发所涉及的各类知识。全书共分16章,内容依次包含了Java EE概述、EJB基础、搭建EJB环境、会话bean、持久化实体、持久化实体...

    EJB概要描述了EJB中最为重要的知识点

    描述了EJB中最为重要的知识点,适合初学者面试以及从整体上认识EJB

    EJB介绍简单的开发

    EJB开发介绍,一些关于EJB的基础知识,以及在企业中的简单应用,交你怎么简单的开发

    EJB的基础知识资料

    EJB的基础知识资料................

    图解eclipse+myelcipse开发EJB

    图解eclipse+myelcipse开发EJB,介绍EJB的配置知识

    EJB相关知识整理1

    EJB的底层是远程方法调用,本质上的目的是把业务逻辑放到服务器上,然后客户端远程调用服务器上的方法来工作,放在服务器上的那些java类就叫EJB,EJB容器是一

    EJB开发总结

    本文适合对于EJB开发需求的程序员,能够为你们提供丰富的EJB必备知识

    ejb 简单应用

    EJB简单应用,讲解分布式EJB操作数据库的知识

    ejb.rar_EJB onetomany_ejb

    EJB基本知识介绍。如OneToOne,OneToMany等经典实例推荐

    EJB基础与项目实战讲解

    学习EJB必备,系统的介绍了EJB的所有知识,再加上相应的项目实战,完全掌握EJB。

    经典JAVA.EE企业应用实战.基于WEBLOGIC_JBOSS的JSF_EJB3_JPA整合开发.pdf

    内容简介 《经典Java EE企业应用实战:基于WebLogic/JBoss的JSF+EJB 3+JPA整合开发》...第二部分详细讲解了JSF RI、EJB 3的Session Bean等Java EE知识;第三部分提供了一个JSF+EJB 3+ JPA整合开发的项目:电子拍卖系统。

Global site tag (gtag.js) - Google Analytics