EJB 学习笔记

1、ejb  基础知识
(1)  无状态会话bean
       不保存客户机的会话状态
       优点:使用小量的实例即可满足大量的客户。每个实例都没有标识,相互之间是等价的。
       等?的无状态会话bean:    多次和一次调用的结果和效应相同。
               在集群中可以负载均衡  a  机器失败,可以在b机器上重试
       非等?的无状态会话bean:  如:计数器
               不能自动因故障而进行切换。

(2)  有状态会话bean
       保存客户机的会话状态
       特点:  在有会话状态会话的bean例子中,出纳员的数量等于活动的顾客的数量,这可以简化编程模式
       weblogic  通过内存复制技术  在集群中进行负载均衡
       内存复制技术:  每个有会话状态的bean实例都将存储在两个服务器的内存中,一个服务器作为主服务器,另一个作为辅助服务器。
       如果主失败,辅助变为主,然后自动选择别的可用的服务器作为辅助。
       遗憾:  很难在servlet  和jsp中用好有状态会话bean。可能会发生并发现象,产生RemoteException
           weblogic  的<allow-concurrent-calls>  可以封锁任何并发的调用。
       同步:  可以有选择地实现  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)</ejb-name>
            <home>com.dhc.helloworld.HelloWorldHome(本地接口类)</home>
            <remote>com.dhc.helloworld.HelloWorld(远程接口类)</remote>
            <ejb-class>com.dhc.helloworld.HelloWorldBean(bean类)</ejb-class>
            <session-type>Stateless(无状态会话)</session-type>
            <transaction-type>Bean(bean管理的事务)</transaction-type>     
        </session>
    </enterprise-beans>
    <container-transaction>
        <method>
            <ejb-name>ShoppingCartEjb</ejb-name>
            <method-name>*(说明ShoppingCartEjb的默认事务属性指定为Required)</method-name>
        </method>
        <trans-attribute>Required(容器管理的事务使用的属性 Nerver、NotSupported
        、Supports、Mandatory、Required、RequiredNew)</trans-attribute>
    </container-transaction>
</ejb-jar>


(2)weblogic-ejb-jar.xml  (注释)

程序代码:
<weblogic-ejb-jar>   
    <weblogic-enterprise-bean>
        <ejb-name>HelloWorld(ejb名称)</ejb-name>
        <jndi-name>HelloWorldEJB(jndi名称)</jndi-name>
        <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(描述)</description>
    <ejb-ref-name>ejb/WidgetEJB</ejb-ref-name>
    <ejb-ref-type>session</ejb-ref-type>
    <home>com.dhc.WidgetHome</home>
    <remote>com.dhc.Widget</remote>
</ejb-ref>


在  weblogic-ejb-jar.xml  


<ejb-reference-description>
       <ejb-ref-name>ejb/WidgeEJB</ejb-ref-name>
       <jndi-name>DeployedWidge</jndi-name>
</ejb-reference-description>

程序

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


7.  资源管理器的引用
定义资源管理的引用
例子:  建立  jdbc、DBPool与JDBC数据源的映射
在ejb-jar.xml

<resource-ref>
       <description>(描述)</description>
       <res-ref-name>jdbc/BDPool</res-ref-name>
       <res-type>javax.sql.DataSource</res-type>
       <res-auth>Container</res-auth>
</resource-ref>

在  weblogic-ejb-jar.xml  

<resource-description>
       <res-ref-name>jdbc/DBPool</res-ref-name>
       <jndi-name>DBPool</jndi-name>
</resource-description>

config.xml

<JDBCTxDataSource  
       name="DBPool"
       Targets="myserver"
       JDDIName="DBPool"  (jndi名称)
       PoolName  ="DevelopmentPool"
/>

引用的优点
我们用大量的映射和配置,才建立了资源管理器的引用,但是还是很值得的。
以为便于部署人员重新配置应用而不需要修改实际的bean类代码。甚至也不需要修改ejb的配置描述器
java  bean  代码

Content  ctx  =  new  InitialContent();
DataSource  dataSource  =  (DataSource)ctx.lookup("java:/comp/env/jdbc/DBPool");

8  .  句柄:  作为一个串行化的对象,句柄中封装了足够的信息,以便重建对EJBObject的引用。
句柄可用于在两个相互合作的进程中传递EJBObject的引用。接受进程即可从句柄中取得EJBObject的引用。

为了取得句柄,可以调用EJBObject接口的getHandle()方法,返回一个Handle实例
为了重建EJBObject  引用。可以使用Handle  接口的getEJBObject()方法。

例子:

HelloWorld  hw  =  home.create();
javax.ejb.Handle  handle  =  hw.getHandle();
HelloWorld  helloworld  =  (HelloWorld)PortableRemoteObject.narrow(handle.getEJBObject(),HelloWorld.class);

 
 HomeHandle:

       类似handle  ,但不能用于引用EJBObject
       HomeHandle  包含足够的信息,可以重建EJBHome()的引用。
       差异:
               是调用  getHomeHandle()方法  和getEJBHome()方法
 例子片断:
         Content  ctx  =  new  InitialContext();
         Object  h  =  ctx.lookup("HelloWorldEJB");
         HelloWorldHome  home  =  (HelloWorldHome)PortableRemoteObject.narrow(h,HelloWorldHome.class);
         HomeHandle  homehandle  =  home.getHomeHandle();
         Object  nh  =  homehandle.getEJBHome();
         HelloWorldHome  newHomeReference  =  (HelloWorldHome)PortableRemoteObject.narrow(nh,HelloWorldHome.class);

 优点:
         他们可以自动的存储重建引用所需的信息

9.使用事务的技巧:
(1)  一个事务不要涉及太多的操作.
(2)  容器管理和bean管理的事务
       事务既耗费应用服务器中的资源,又耗费数据库资源,所以事务越短越好.
       尽量使用容器管理事务而不要采用bean管理事务的方式.
(3)  ejb遇到错误,需要强制事务回滚.  使用EJBObject.setRollbackOnly();
(4)  不能让事务涉及web层和表示逻辑
(5)  企业应用中不应当选用supports  事务属性,因为只有调用者开始一个事务后,ejb才能在事务中运行.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/467056.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言——项目规范

C语言——项目规范 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 //基本原则 1、尽量少使用全局变量&#xff0c;或者说禁止使用全局变量&#xff1b; 2、实在要在其他文件使用本文件中的变量&#xff0c;以函数接口返回其值&#xff0c;在其他文件…

折半查找判定树及平均查找长度

折半查找判定树及平均查找长度 从折半查找的过程看&#xff0c;以有序表的中间记录作为比较对象&#xff0c;并以中间记录将表分割为两个子表&#xff0c;对子表继续上述操作。所以&#xff0c;对表中每个记录的查找过程&#xff0c;可用二叉树来描述&#xff0c;二叉树中的每个…

华为开始对嵌入式开发者下手了!

5G时代到来&#xff0c;物联网技术的应用也离我们越来越近。智慧交通、智能家庭、智慧园区&#xff0c;越来越多的融入到我们的生活当中。作为物联网重要技术组成的嵌入式系统&#xff0c;嵌入式系统视角有助于深刻地、全面地理解物联网的本质。而物联网是通用计算机的互联网与…

慎用Hyper-Threading Technology

今天&#xff0c;一个同事遇到了一个非常奇怪的问题&#xff0c;他的程序&#xff08;C#&#xff09;运用了Hyper-Threading技术&#xff0c;系统用的是Windows 2000 SP4&#xff0c;当程序运行时会随机的抛出一个异常&#xff0c;而且这个bug很不容易reproduce&#xff0c;最后…

BZOJ1876 [SDOI2009]SuperGCD 【高精 + GCD优化】

题目 Sheng bill有着惊人的心算能力&#xff0c;甚至能用大脑计算出两个巨大的数的GCD&#xff08;最大公约 数&#xff09;&#xff01;因此他经常和别人比 赛计算GCD。有一天Sheng bill很嚣张地找到了你&#xff0c;并要求和你比 赛&#xff0c;但是输给Sheng bill岂不是很丢…

二叉排序树和平衡二叉排序树

二叉排序树又称为二叉查找树&#xff0c;它是一颗特殊的二叉树。&#xff08;空树&#xff09; 性质&#xff1a;1、若它的左子树非空&#xff0c;则左子树上的所有结点的值均小于根结点的值。 2、若它的右子树非空&#xff0c;则右子树上的所有结点的值均大于根结点的值。 3、…

C语言九阳神功

C语言笔记(九阳神功) 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 1.static的作用&#xff1a; &#xff08;1&#xff09;在函数体内&#xff0c;一个被声明为静态的变量在这一函数被调用过程中维持其值不变&#xff08;该变量存放在静态变量区&…

FUSE文件系统

Fuse(filesystem in userspace),是一个用户空间的文件系统。通过fuse内核模块的支持&#xff0c;开发者只需要根据fuse提供的接口实现具体的文件操作就可以实现一个文件系统。由于其主要实现代码位于用户空间中&#xff0c;而不需要重新编译内核&#xff0c;这给开发者带来了众…

myeclipse试用小记----Hibernate多对一双向关联(2)

myeclipse试用小记----Hibernate多对一双向关联&#xff08;2&#xff09;在上篇文章“myeclipse试用小记----Hibernate多对一单向关联&#xff08;1&#xff09;”中&#xff0c;讲到了“Hibernate多对一单向关联”&#xff0c;现在我打算把这个做成双向的&#xff0c;也就是多…

Python的程序结构[4] - 函数/Function[2] - 匿名函数

匿名函数 / Anonymous Function 匿名函数是一种不需要绑定函数名的函数 (i.e. functions that are not bound to a name)。匿名函数通过 lambda 表达式进行构建。常用于快速建立起一个(一次性的)函数。 Note: lambda 是 Python 的一个表达式/关键字&#xff0c;类似 return&…

数组 的地址计算

数组是一个特殊的数据结构&#xff0c;数组的基本操作不涉及数组结构的变化&#xff0c;因此对于数组而言&#xff0c;采用顺序存储表示比较合适。数组的顺序存储结构有两种&#xff1a;一、以行序存储&#xff0c;如高级语言BASIC、COBOL、Pascal、c语言。二、以列序存储&…

你会选择深圳还是佛山?

最近是校招季节&#xff0c;有很多人在询问offer的问题&#xff0c;我知道我已经发了很多这样相关的文章&#xff0c;可能大家看着都有点不耐烦了&#xff0c;不过还是想说&#xff0c;人生重要的选择真的没有几个&#xff0c;我每次回答都特别慎重&#xff0c;我有时候发出来也…

盗版XP变正版

此帖为转贴&#xff01;经本人测试100&#xff05;成功&#xff0c;谨以此帖献给各位目前不能更新的猫们&#xff0c;免得四处搜寻&#xff0c;徒劳无功&#xff01;一、经过无数次验证&#xff0c;本方法绝对有效&#xff01;敬请一试&#xff01;&#xff01;1。点击开始栏→…

区间K大数查询

给定一个序列&#xff0c;每次询问序列中第l个数到第r个数中第K大的数是哪个。输入格式第一行包含一个数n&#xff0c;表示序列长度。第二行包含n个正整数&#xff0c;表示给定的序列。第三个包含一个正整数m&#xff0c;表示询问个数。接下来m行&#xff0c;每行三个数l,r,K&a…

optimizer

在很多机器学习和深度学习的应用中&#xff0c;我们发现用的最多的优化器是 Adam&#xff0c;为什么呢&#xff1f; 下面是 TensorFlow 中的优化器&#xff0c; https://www.tensorflow.org/api_guides/python/train 在 keras 中也有 SGD&#xff0c;RMSprop&#xff0c;Adagr…

【漫画】25岁程序员 VS 35岁程序员,塑造自己的不可替代性,才能让自己更有价值 ​...

其中的酸甜苦辣你中了几条经常有人说&#xff1a;35岁是程序员的魔咒。但其实相比于刚毕业的年轻人&#xff0c;虽然35岁的程序员从精力上和年龄上都不再占有优势&#xff0c;但十几年的沉淀所造就的从容也是这个年龄段所独有的。当然&#xff0c;也不只是程序员&#xff0c;任…

C语言——内存管理

C语言——内存管理 宗旨&#xff1a;技术的学习是有限的&#xff0c;分享的精神是无限的。 //变量的存储布局&#xff08;伴随初级程序员和高级工程师一生的&#xff09; 静态区&#xff1a;全局变量和static变量&#xff0c;初始化的全局变量和静态变量放在一块区域&#xf…

WIN命令

azman.msc--授权管理器admgmt.msc--ad管理calc-----------启动计算器certmgr.msc--证书&#xff0d;当前用户certtmpl.msc--证书模板 compmgmt.msc---计算机管理conf-------启动netmeetingcys--配置您的服务器dcomcnfg.exe--组件服务dcpol.msc--域控制器策略 filesvr.msc--文件…

拦截导弹

拦截导弹 时间限制&#xff1a;3000 ms | 内存限制&#xff1a;65535 KB难度&#xff1a;3描述某国为了防御敌国的导弹袭击&#xff0c;发展中一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷&#xff1a;虽然它的第一发炮弹能够到达任意的高度&#xff0c;但是以后每一发…

C标准库

嘤嘤嘤&#xff0c;C标准库&#xff0c;我来了转载于:https://www.cnblogs.com/Fsiswo/p/8116331.html