EJB是sun的JavaEE服务器端组件模型,设计目标与核心应用是部署分布式应用程序。简单来说就是把已经编写好的程序(即:类)打包放在服务器上执行。凭借java跨平台的优势,用EJB技术部署的分布式系统可以不限于特定的平台。EJB (Enterprise JavaBean)是J2EE(javaEE)的一部分,定义了一个用于开发基于组件的企业多重应用程序的标准。其特点包括网络服务支持和核心开发工具(SDK)。 在J2EE里,Enterprise Java Beans(EJB)称为Java 企业Bean,是Java的核心代码,分别是会话Bean(Session Bean),实体Bean(Entity Bean)和消息驱动Bean(MessageDriven Bean)。在EJB3.0推出以后,实体Bean被单独分了出来,形成了新的规范JPA。

简介


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

EJB_业务逻辑EJB

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

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


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


EJB实际上是SUN的J2EE中的一套规范,并且规定了一系列的API用来实现把EJB概念转换成EJB产品。


 



EJB


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

EJB_业务逻辑_02EJB

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

可扩展 (Scalable)


分布式 (Distributed)


事务处理(Transactional)


数据存储(Persistent)


安全性 (Secure)


 



期望


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


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


Write once, run anywhere


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


兼容CORBA标准


 



选择EJB


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


支持事务处理


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


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

EJB_ejb_03EJB

可扩展性

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


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


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


 



EJB 架构


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


服务器 (Server)


容器(Container)


类 (Class) 和实例 (Instance)


Home 和 Remote 接口


客户端(Client)


 



编程模型


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


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


Java 是其编程语言


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


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


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


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


有三种类型的 enterprise beans:session beans、entity beans 和 message-driven beans。


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


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


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


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


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