图解EJB的体系结构

软考 同时被 3 个专栏收录
59 篇文章 1 订阅
18 篇文章 2 订阅
10 篇文章 0 订阅

什么是EJB:(百度百科)

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

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在J2EE体系结构中的位置
  • EJB的环境构成
  • EJB的资源配置
  • EJB的种类
  • EJB组件的构造
  • EJB的调用过程
  • EJB组件的生命周期

EJB是Enterprise JavaBeans的简称。本文对EJB技术的体系结构作一个全面深入地介绍。

EJB在J2EE体系结构中的位置

视图层或表现层:提供用户界面;接收用户输入;数据输出。WEB应用的情况,JSP以及SERVLET属于视图层组件。

业务逻辑层:实际的业务逻辑处理。根据视图层传送过来的数据,进行实际的业务逻辑处理(包括数据库的查询,更新等),再把处理后的结果返回给视图层。EJB,以及不使用EJB的情况下担当业务逻辑处理部分的JavaBean等归属于业务逻辑层组件。

数据库层或数据持久化层:多指用于保存业务数据的数据库,也可以是文件等等。

EJB属于J2EE体系结构中的业务逻辑层部分。

EJB的环境构成

1,EJB组件运行在EJB容器之中,EJB容器是一个EJB引擎,它提供了EJB组件运行的环境,并对EJB组件进行管理。EJB容器一般包含在EJB服务器(或应用服务器)中,EJB服务器可以拥有一到多个EJB容器。比较有名的支持EJB的服务器有Sun One,Interstage,Websphere,Weblogic,JBoss,JRun等。

2,调用EJB组件的一方被称为EJB客户端。EJB客户端可以为运行在WEB容器中的JSP,SERVLET;或者一般的Java Application,Applet;或者Web Service;也可以是别的EJB组件。

3,EJB客户端与EJB服务器可处于同一JVM环境中,也可处于不同计算机的不同JVM环境。

EJB的资源配置

当一个EJB组件被开发完成之后,它需要以JAR文件的形式配置到EJB容器中以备其他客户程序 使用;反过来,一个客户程序需要使用某EJB组件,该客户程序需要引用该EJB组件的接口,也就是说,EJB的jar文件需要同时配置到EJB容器和使用 该EJB组件的客户端环境中。

如图:

EJB-JAR文件的构成

sample-ejb.jar

EJB-JAR文件是一个后缀名为.jar的zip格式文件。它至少需要包含META-INF目录以及其下的ejb-jar.xml文件以及MANIFEST.MF文件。对于不同类型的EJB组件,还需包含它们的Home接口,组件接口,以及组件的实现类。

EJB组件的种类

EJB组件有SessionBean(会话Bean),EntityBean(实体Bean),MDB(消息驱动Bean)三种。

SessionBean

主要负责业务逻辑的处理。根据处理时的状态保持与否,SessionBean又被分为:

Stateful SessionBean(有状态SessionBean)

Stateless Bean(无状态SessionBean)

对象的“状态”是指对象的属性值,也就是对象所携带的数据。Stateful SessionBean能维持会话的状态,就是说能为同一客户端保持上一回被调用时的状态,类似于HttpSession;而Stateless SessionBean则不能维持会话状态,也就是说,对Stateless SessionBean来说,每个方法都是独立的,因为对特定客户端不保持会话状态,所以一般也不在Stateless SessionBean里定义成员变量。

EntityBean

负责数据库的访问。通常由SessionBean调用。EntityBean的一个实例所表示的数据通常代表了关系数据库中特定表的特定的一行数据。EJB3开始,EntityBean部分的功能可以通过JPA来实现。

EntityBean的作用:

1,对数据库的操作:查询,数据的更新,删除等

2,数据库表数据的携带

根据对数据库操作(持久化)的不同,EntityBean分为以下2种类型:

1,BMP (Bean-managed persistence:bean管理持久化):持久化操作(数据库的访问,数据的创建,更新,删除等)由EntityBean的实现(javax.ejb.EntityBean的实现类)自身完成。

2,CMP (Container-managed persistence:容器管理持久化):持久化操作由容器根据deploy时的配置信息(ejb-jar.xml)自动完成。

MDB (message-driven bean:消息驱动bean)

MDB主要用来处理异步消息。客户端调用SessionBean,EntityBean的方法时,会一直处于等待状态,直到被调用的方法处理完毕。但使用 MDB,客户端向容器发送一个JMS消息之后,不必等待MDB处理完毕便可直接返回。JMS被发送给由容器管理的JMS消息队列,容器在适当的时候通知 MDB的callback方法onMessage加以处理。一个MDB需要实现javax.jms.MessageListener接口与 javax.ejb.MessageDrivenBean接口。

EJB组件的构造

构造图:

SessionBean的UML-CLASS图

EntityBean的UML-CLASS图

MDB的UML-CLASS图

EJB的调用过程

①客户端程序使用lookup方法查找JNDI

②EJB服务器的JDNI服务根据事先登录的信息匹配lookup查询内容,生成Home实例

③客户端得到对Home实例的引用

④客户端调用Home.create方法

⑤创建相对应的Bean实例,调用Bean的ejbCreate方法

⑥生成相对应的Remote Ojbect实例

⑦客户端得到对Remote Ojbect实例的引用

⑧客户端掉用业务逻辑方法

客户端与服务器端的通信使用RMI-IIOP通信协议。

客户端在调用EJB组件时,需要知道EJB组件的位置(包括IP,端口,名称),才能得到对EJB组件对象的引用。JNDI是J2EE提供的一套Java API,是Java Naming and Directory Interface的略称,提供根据名称查找对象的服务。EJB利用JNDI来解决名称问题。JNDI有Service Provider的概念,Provider可以选择LDAP或者RMI。

要使用JNDI,需要先进行登录,然后使用lookup进行查找。

EJB的JNDI的使用,也需要通过配置文件进行登录,不同的EJB服务器有不同的设置方法。具体可参考相关EJB服务器的操作手册。

EJB组件的生命周期(Lifecycle)

Stateful SessionBean的生命周期

顺序图(sequence图)

Stateless SessionBean的生命周期

顺序图(sequence图)

 

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 扫一扫,分享海报

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值