EJB

原创 2007年09月27日 13:29:00
 
 

1、ejb 基础知识
(1) 无状态会话bean
    不保存客户机的会话状态
    优点:使用小量的实例即可满足大量的客户。每个实例都没有标识,相互之间是等价的。
    等?的无状态会话bean:  多次和一次调用的结果和效应相同。
        在集群中可以负载均衡 a 机器失败,可以在b机器上重试
    非等?的无状态会话bean: 如:计数器
        不能自动因故障而进行切换。
(2) 有状态会话bean
    保存客户机的会话状态
    特点: 在有会话状态会话的bean例子中,出纳员的数量等于活动的顾客的数量,这可以简化编程模式
        weblogic 通过内存复制技术 在集群中进行负载均衡
            内存复制技术: 每个有会话状态的bean实例都将存储在两个服务器的内存中,一个服务器作为主服务器,另一个作为辅助服务器。
                         如果主失败,辅助变为主,然后自动选择别的可用的服务器作为辅助。
    遗憾: 很难在servlet 和jsp中用好有状态会话bean。可能会发生并发现象,产生RemoteException
          weblogic 的 可以封锁任何并发的调用。
    同步: 可以有选择地实现 javax.ejb.SessionSynchronization接口
          afeterBegin()         //进入事务时
          beforeCompletion()    //提交事务前,用于提交前把缓存的数据写到数据库中.
          afterCompletion()     //提交事务后,用于释放共享资源或者更新事务提交和终止方面的统计信息.
     会话bean通过其 SessionContext 对象中的 getUserTransaction() 方法,取得对UserTransaction的应用
     通常 SessionContext 被存放在成员变量中
     ** 记住是在调用ejb.create()方法前调用 setUserTransaction() 方法
     利用对 UserTransaction 的引用会话可以使用 begin() 、commit()、rollback() 方法界定一个事务.

           
(3) 实体 bean: 
    它有一个主健作为唯一的标识符
    组成部分: 由本地接口、远程接口、bean类、主健类和配置描述器组成。
             本地接口:
                 扩展了javax.ejb.EJBHome接口,包括create()、remove()、finder 和home等方法
                 1)create()方法调用bean类中的ejbCreate()方法。相当于数据的insert 方法。
                 2)remove()方法相当于数据库的delete操作。
                 3)finder()方法,使客户能够查询和接收满足查询条件的实体bean的引用。每个实体bean的本地接口中都必须
                   有一个findByPrimaryKey() 方法
                 4)home 方法,类似于无状态会话bean。
             主健类:
                 实体bean必须包括一个主健类,主健类用于标识实体bean实例,而且实体bean数据类型必须是唯一的。
                 主健类可以是java的基本类型String Integer 也可以是用户自定义的。
                 也可以是多个字段的主健的复合主健。
             bean 类和bean的上下文环境:
                 实现javax.ejb.EJBObject 接口,其中包含业务方法的语法格式定义.
                 bean 类实现了javax.ejb.EntityBean接口,同javax.ejb.SessionBean接口一样,EntityBean 接口包含了EJB
                 容器调用bean实例的语法格式.
                 在bean的构造器执行之后,立即调用setEntityContext() 方法,同时把bean实例的EntityContext 传递给它.
                 bean类实现了home方法和远程接口中的业务方法,home方法是针对匿名实例的方法不应使用有关的主健值.

    分为:
    容器管理持久性(Container-Managerd Persistence)CMP
        特点: EJB 容器自动生成,用于把实体bean的数据写入到数据库中。
        优点: bean作者可以避免编写实体bean与关系数据库数据访问方面的代码。cmp将自动处理这一过程。
        个性:  每一个cmp 实体bean 都有一组容器管理的字段,这些字段存储在数据库,并可从中加载.通常,每个容器管理的字段都对应于
              关系数据库中的一个列.
              容器管理的每个字段必须在ejb-jar.xml中定义,这使容器能够把容器管理的字段与bean类中的set和get方法进行匹配比较.
              另外,bean作者可以增加另外一个cmp配置描述文件 weblogic-cmp-rdbms.xml,其中包含数据库表名和每个容器管理的字
              段和相应的数据列的映射.

    bean管理持久性(Bean-Managerd Persistence ) BMP
        特点: 在bmp实体中,bean作者需要自己编写数据库访问代码,也就是编写JDBC代码,插入、删除和查询数据库中的实体bean数据。
        优点: 可以让bean的作者完全灵活的处理实体bean的持久性数据,因为作者需要写数据访问的代码,他几乎可以使用任何持久性存
              储方式ejb2.0 cmp提供实体bean之间的标准关系映射,使容器能自动管理业务对象之间的交互。
              cmp拥有更多的访问控制,因此cmp比bmp有较好的性能。

(4) 消息 bean
    把JMS 和EJB 成功结合在一起,集成的结果
    特点:客户机不需要调用消息bean 相反: 客户机只需要发一个消息给jMS目的。
    在消息到达以后,消息bean的onmessage()方法将被调用,以处理这个消息。
    消息bean用于在服务器中执行异步操作。

2。EJB 组成
(1)远程接口
    public interface HelloWord extents EJBObject
    {
        //EJBObject 接口方法
         EJBHome getEJBHome() throws RemoteException;

        Object getPrimaryKey() throws RemoteException;

        void remove() throws RemoteException, RemoveException;

        Handle getHandle() throws RemoteException;

        boolean isIdentical(EJBObject ejbObject) throws RemoteException;
    }
(2)本地接口
    本地接口是ejb工厂,客户机可以使用本地接口创建、找出和删除ejb实例。只需写本地接口中的方法的语法调用格式
    public class HelloWorldHome extends EJBHome
    {
        //EJBHome 接口方法
        void remove(Handle handle) throws RemoteException, RemoveException;

        void remove(Object o) throws RemoteException, RemoveException;

        EJBMetaData getEJBMetaData() throws RemoteException;

        HomeHandle getHomeHandle() throws RemoteException;
        // Home
        public HelloWorld create() throws CreateException, RemoteException;
    }

(3)bean 类
    
    public class HelloWorldBean implements SessionBean
    {
        // SessionBean 中的方法
        public void setSessionContext(SessionContext sessionContext) 
        /**调用次方法会话结束*/
        public void ejbRemove() 
            //ejb通过待命和活动的机制,管理一组正在工作的有状态会话bean实例
        /**活动*/
        public void ejbActivate() 
        /**待命*/
        public void ejbPassivate() 
        // bean类
        // 每个home 的create 方法对应一个ejbCreate()方法
        // 有会话状态有很多不同版本的create()方法。而create 方法必须有ejbCreate()方法与之一一对应
        public void ejbCreate()


    }

    不要在ejb类中类中实现远程接口
3. EJB 配置描述器
(1)ejb-jar.xml
< ejb-jar> (注释)  
    < enterprise-beans>     
        < session>
            < ejb-name>HelloWorld(ejbname)
            < home>com.dhc.helloworld.HelloWorldHome(本地接口类)
            < remote>com.dhc.helloworld.HelloWorld(远程接口类)
            < ejb-class>com.dhc.helloworld.HelloWorldBean(bean类)
            < session-type>Stateless(无状态会话)
            < transaction-type>Bean(bean管理的事务)     
        < /session>
    < /enterprise-beans>
    < container-transaction>
        < method>
            < ejb-name>ShoppingCartEjb
            < method-name>*(说明ShoppingCartEjb的默认事务属性指定为Required)< /method-name>
        < /method>
        < trans-attribute>Required(容器管理的事务使用的属性 Nerver、NotSupported
        、Supports、Mandatory、Required、RequiredNew)
    < /container-transaction>
< /ejb-jar>
(2)weblogic-ejb-jar.xml (注释)
< weblogic-ejb-jar>   
    < weblogic-enterprise-bean>
        < ejb-name>HelloWorld(ejb名称)
        < jndi-name>HelloWorldEJB(jndi名称)
        < max-bean-in-freepool>10(限制不会有超过10个无状态会话bean并发运行)< /max-bean-in-freepool>
        < max-bean-in-cache>10(放到内存缓存中的有状态会话bean的最大数量)< /max-bean-in-cache>
    < /weblogic-enterprise-bean>
< /weblogic-ejb-jar>  

4 . 建立ejb 档案文件
com/dhc/helloworld/(package)
com/dhc/helloworld/HelloWorld(远程接口)
com/dhc/helloworld/HelloWorldHome(本地接口)
com/dhc/helloworld/HelloWorldBean(bean类)
META-INF
META-INF/ejb-jar.xml(配置描述器)
META-INF/weblogic-ejb-jar.xml(weblogic服务器配置描述器)

说明: META-INF 必须为大写

5 . 容器管理的事务
Nerver :        不参与事务,如果参与产生RemoteException
NotSupported:   不能参与
Supports:       如果调用者正在参与事务,相应的EJB调用也可以参与事务,否则不能
Mandatory       如果调用者有一个事务,相应的EJB可以参与事务,否则,TransactionRequiredException
Required        如果调用者有一个事务,相应的EJB可以参与事务,否则,容器将在调用相应的EJB之前,开始一个事务.
                当方法调用完成以后,即提交该事务.
RequiresNew     在调用相应的EJB之前,开始一个新的事务,当方法调用返回时,即提交这个事务.


6、ejb 引用

在ejb-jar.xml
< ejb-ref>
    < description> an EJB reference to the Widget EJB(描述)
    < ejb-ref-name>ejb/WidgetEJB
    < ejb-ref-type>session
    < home>com.dhc.WidgetHome
    < remote>com.dhc.Widget
< /ejb-ref>

在 weblogic-ejb-jar.xml 
< ejb-reference-description>
    < ejb-ref-name>ejb/WidgeEJB
    < jndi-name>DeployedWidge
< /ejb-reference-description>

程序
Content ctx = new InitialContent();
Object h = ctx.lookup("java:/comp/env/ejb");    //环境变量是只读的,而且是当前ejb的本地变量.
WidgetHome home = (WidgetHome)PortableRemoteObject.narrow(h,WidgeHome.class);

 



杀70万种木马病毒,瑞星2008版免费 

相关文章推荐

EJB3.0入门一(黎活明老师视频笔记)

1.什么是EJB    EJB(Enterprice JavaBeans)是一个用于分布式业务应用的标准服务端组件模型。采用EJB架构编写的应用是可伸的、事务性的、多用户安全的。 2.EJB用来干...

OpenEjb使用笔记--让Tomcat可以部署EJB

http://qujianfeng.iteye.com/blog/793409 1  OpenEJB概述       Tomcat本不支持部署EJB,通过向其安装OpenEjb,可使其支持...

EJB3-远程、本地调用

做个笔记以免忘记了。      EJB远程调用使用scoket通信,遵循IIOP协议,对象要经过序列化才能传输。有网络的开销,协议的开销,对象序列化的开销。      EJB和客户端分别部署在不同...

解读Ejb中Local与Remote项目

在高校平台项目中使用到了Ejb。刚开始的时候,大家都不太懂得Local与Remote的含义、用法以及区别。这里我进行了总结,跟大家分享了一下。 中文翻译过来的意思就很明确了:Local是本地接口;Re...

Java EE开发系列教程 - 使用EJB组件与JPA层交互

英文同步版链接Github项目源码EJB 全称为Enterprise Java Beans,封装了应用程序的业务逻辑并提供与容器服务交互的能力,如事务和安全。本教程在上次创建的JPA模块的基础上,继续...

EJB3基本概念、运行环境、下载安装与运行jboss

EJB3基本概念 什么是EJB:          EJB(EnterpriceJavaBeans)是一个用于分布式业务应用的标准服务端组件模型。采用EJB架构编写的应用是可伸的、事务性的、多用户安全...

EJB到底是什么,真的那么神秘吗??

1. 我们不禁要问,什么是"服务集群"?什么是"企业级开发"?  既然说了EJB 是为了"服务集群"和"企业级开发",那么,总得说说什么是所谓的"服务 集群"和"企业级开发"吧! 这个问题其实挺...

EJB3.0 有状态会话bean无状态会话bean详解

在网上看到了这一篇文章详细描述了两种会话hean的区别,但因转载的人实在太多了,所以无法注明原文出处。只好用原创表示,对于文章的原创者,表示尊敬。   下面主要对Session  Bean...

带你走进EJB--MDB

在之前的文章中我们介绍了带你走进EJB--JMS 和 带你走进EJB--JMS编程模型 对JMS有了初步的了解, 作为EJB系列的文章我们会继续对EJB相关的内容做进一步深的学习和了解....
  • jnqqls
  • jnqqls
  • 2013年08月31日 17:00
  • 3152

EJB与Spring的全面比较与JavaBean的不同

一:EJB与Spring的全面比较Rod Johnson将Indeed.com(一个求职网站)职位列表中对EJB和Spring两种技能的需求数量进行了对比,并通过分析这一统计数据得出了一些关于EJB的...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:EJB
举报原因:
原因补充:

(最多只允许输入30个字)