<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    飛艷小屋

    程序--人生--哲學___________________歡迎艷兒的加入

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      52 Posts :: 175 Stories :: 107 Comments :: 0 Trackbacks
    Weblogic EJB 學習筆記
    littleboys 原創(chuàng)  (參與分:47498,專家分:330)   發(fā)表:2003-06-18 11:16   版本:1.0   閱讀:12529

    EJB 學習筆記
    1、ejb 基礎知識
    (1) 無狀態(tài)會話bean
        不保存客戶機的會話狀態(tài)
        優(yōu)點:使用小量的實例即可滿足大量的客戶。每個實例都沒有標識,相互之間是等價的。
        等?的無狀態(tài)會話bean:  多次和一次調用的結果和效應相同。
            在集群中可以負載均衡 a 機器失敗,可以在b機器上重試
        非等?的無狀態(tài)會話bean: 如:計數器
            不能自動因故障而進行切換。
    (2) 有狀態(tài)會話bean
        保存客戶機的會話狀態(tài)
        特點: 在有會話狀態(tài)會話的bean例子中,出納員的數量等于活動的顧客的數量,這可以簡化編程模式
            weblogic 通過內存復制技術 在集群中進行負載均衡
                內存復制技術: 每個有會話狀態(tài)的bean實例都將存儲在兩個服務器的內存中,一個服務器作為主服務器,另一個作為輔助服務器。
                             如果主失敗,輔助變?yōu)橹?,然后自動選擇別的可用的服務器作為輔助。
        遺憾: 很難在servlet 和jsp中用好有狀態(tài)會話bean。可能會發(fā)生并發(fā)現象,產生RemoteException
              weblogic 的<allow-concurrent-calls> 可以封鎖任何并發(fā)的調用。
        同步: 可以有選擇地實現 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 方法,類似于無狀態(tài)會話bean。
                 主健類:
                     實體bean必須包括一個主健類,主健類用于標識實體bean實例,而且實體bean數據類型必須是唯一的。
                     主健類可以是java的基本類型String Integer 也可以是用戶自定義的。
                     也可以是多個字段的主健的復合主健。
                 bean 類和bean的上下文環(huán)境:
                     實現javax.ejb.EJBObject 接口,其中包含業(yè)務方法的語法格式定義.
                     bean 類實現了javax.ejb.EntityBean接口,同javax.ejb.SessionBean接口一樣,EntityBean 接口包含了EJB
                     容器調用bean實例的語法格式.
                     在bean的構造器執(zhí)行之后,立即調用setEntityContext() 方法,同時把bean實例的EntityContext 傳遞給它.
                     bean類實現了home方法和遠程接口中的業(yè)務方法,home方法是針對匿名實例的方法不應使用有關的主健值.

        分為:
        容器管理持久性(Container-Managerd Persistence)CMP
            特點: EJB 容器自動生成,用于把實體bean的數據寫入到數據庫中。
            優(yōu)點: 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數據。
            優(yōu)點: 可以讓bean的作者完全靈活的處理實體bean的持久性數據,因為作者需要寫數據訪問的代碼,他幾乎可以使用任何持久性存
                  儲方式ejb2.0 cmp提供實體bean之間的標準關系映射,使容器能自動管理業(yè)務對象之間的交互。
                  cmp擁有更多的訪問控制,因此cmp比bmp有較好的性能。

    (4) 消息 bean
        把JMS 和EJB 成功結合在一起,集成的結果
        特點:客戶機不需要調用消息bean 相反: 客戶機只需要發(fā)一個消息給jMS目的。
        在消息到達以后,消息bean的onmessage()方法將被調用,以處理這個消息。
        消息bean用于在服務器中執(zhí)行異步操作。

    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工廠,客戶機可以使用本地接口創(chuàng)建、找出和刪除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通過待命和活動的機制,管理一組正在工作的有狀態(tài)會話bean實例
            /**活動*/
            public void ejbActivate() 
            /**待命*/
            public void ejbPassivate() 
            // bean類
            // 每個home 的create 方法對應一個ejbCreate()方法
            // 有會話狀態(tài)有很多不同版本的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(無狀態(tài)會話)</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個無狀態(tài)會話bean并發(fā)運行)</max-bean-in-freepool>
            <max-bean-in-cache>10(放到內存緩存中的有狀態(tài)會話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");    //環(huán)境變量是只讀的,而且是當前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"
    />

    引用的優(yōu)點
    我們用大量的映射和配置,才建立了資源管理器的引用,但是還是很值得的。
    以為便于部署人員重新配置應用而不需要修改實際的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 引用??梢允褂肏andle 接口的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);

     優(yōu)點:
         他們可以自動的存儲重建引用所需的信息

    9.使用事務的技巧:
    (1) 一個事務不要涉及太多的操作.
    (2) 容器管理和bean管理的事務
        事務既耗費應用服務器中的資源,又耗費數據庫資源,所以事務越短越好.
        盡量使用容器管理事務而不要采用bean管理事務的方式.
    (3) ejb遇到錯誤,需要強制事務回滾. 使用EJBObject.setRollbackOnly();
    (4) 不能讓事務涉及web層和表示邏輯
    (5) 企業(yè)應用中不應當選用supports 事務屬性,因為只有調用者開始一個事務后,ejb才能在事務中運行.
    基于weblogic 的ejb 學習筆記(二)

    編輯實體bean的高級課程
    1. 怎樣開發(fā)主健類
    ejb的主健類主要用做持久存儲和ejb容器中的唯一標識符.
    通常主健類的字段直接映射到數據庫中的主健字段.
    如果主健只是由單個實體bean字段組成.且其數據類型是基本的java類.如string,則bean作者不必開發(fā)自定義的主健類.
    只需要在配置描述器中指定類的名字和主健字段即可

    如果把主健映射到一個用戶定義的類型,或者映射到多個字段,則bean的作者必須寫出自定義的主健類.

    主健類必須實現 java.io.serializable,而且包含主健字段.

    對于cmp,字段名必須匹配實體bean中的相應的主健字段名,這將使ejb容器能夠把適當的cmp字段賦值到主健類中的相應字段中.

    2. 實現hashcode()方法
    hashcode() 方法的實現原理是,利用主健字段,經適的處理后,生成并返回一個整數. 這個生成的整數稱為散列碼,用作表格的索引.
    對于一個給定的主健,hashcode()方法的返回值應當總是一樣的. 常見做法: 執(zhí)行"異或" 操作.

    3. 實現 equals() 方法
     正確地實現equals()方法也需要一定的技巧. 任何equals() 方法的第一行都應當檢查傳遞進來的引用是否是"this", 檢查equals()
     方法是否是針對自己的調用. 通常做法: 當容器有一個主健對象時,她要檢查這個主健對象是否已經存在于數據結構中.

     接著,equals() 方法需要檢查傳遞進來的主健類的類型. 如果主健類是中繼類(final),可以使用instanceof 進行簡單的檢查.
     否則,傳遞進來的參數也許是主健類的子類.在這種情況下,equals() 方法必須使用getClass.equals, 以確保類的類型是匹配的

     建議主健類采用終極類. (instanceof 效率要高一些)

     最后,equals() 方法需要需要比較傳遞進來的對象的所有值. 如果所有值是相同的,說明對象也是相同的
     注意: 要先比較散列碼.

     4 實體bean的繼承和異構
       實體bean 可以利用java的繼承和異構的特性.

    5. 繼承的限制
    盡管ejb 規(guī)范允許組件之間的繼承,但夜游一些細微的規(guī)則限制了怎樣設計和實現一個繼承的ejb.
     ejb的規(guī)則要求,本地接口的create() 方法返回的遠程接口不能是一個子類,也不能是超類. 實體bean 的ejbreate() 方法也
     必須返回主健類型,也不能是一個子類,也不能是超類.
    類似的findByPrimaryKey()方法必須使用主健類型作為參數返回遠程接口.
    這些要求限制了bean作者對繼承的實現.

    6. 繼承和異構的設計模式

    注意: 具有繼承和異構特性的實體bean,很重要一點就是要確定一般情況下究竟都需要使用哪一些屬性.

    7 . 接口的繼承

    通過bean類的繼承性,bean作者只需要在一個地方實現業(yè)務方法,其它實體bean就可以共享類中的方法了.

    8 使用多個bean類
      為本地和遠程接口創(chuàng)建一個基本接口,不是達到異構共享的唯一方法. 另一個常見的做法是
      使用等同的本地和遠程接口,但采用不同的bean類實現其中的業(yè)務方法.
      這種做法類似于使用一個具有若干不同實現的接口. 
      好處: 客戶不知道或根本不管正在使用哪一種實現,客戶機只對接口進行操作.

    9. 實體bean 與鎖

        實體bean 不是可重入的或多線程的組件,每個實體bean實例也沒有多線程控制的能力。
    一次實體bean 類中的方法也不是同步化的。
        實體bean實例不能是多線程的,所以ejb容器必須串行地執(zhí)行所有的容器方法和業(yè)務方法。
    這意味著當業(yè)務方法正在執(zhí)行時,ejb容器不能再調用其它方法,比如 ejbPassivate()方法。

        并發(fā)控制:
            一種做法是對每一個事務都激活實體bean實例。同過數據庫的訪問鎖的方式進行并發(fā)處理。
            一種方法是,每一個主健只保持一個實體bean實例,這樣一次只有一個事務可以訪問實體bean。一旦
                前一個事務提交或回滾,才允許另一個事務使用這個實體bean實例。
        并發(fā)控制策略:
            數據庫并發(fā)控制:
                除非特別情況,應盡量使用默認的數據庫并發(fā)控制。
            排它性并發(fā)控制:
    posted on 2005-12-14 15:33 天外飛仙 閱讀(287) 評論(0)  編輯  收藏 所屬分類: EJB

    只有注冊用戶登錄后才能發(fā)表評論。


    網站導航:
     
    主站蜘蛛池模板: 永久黄色免费网站| 四虎永久免费观看| 国产成人高清亚洲一区久久| 亚洲av区一区二区三| 久久国产乱子免费精品| 成人亚洲国产va天堂| 亚洲色偷偷综合亚洲AVYP| 中文字幕无码成人免费视频| 大片免费观看92在线视频线视频| 亚洲AV无码国产精品色午友在线| 在线观看无码的免费网站| 国产色爽免费无码视频| 亚洲第一第二第三第四第五第六| 亚洲AV无码欧洲AV无码网站| 最近2019中文免费字幕| 色www永久免费网站| 亚洲国产美女精品久久久| 久久狠狠高潮亚洲精品| 一级毛片直播亚洲| 114一级毛片免费| 不卡视频免费在线观看| 久久人午夜亚洲精品无码区| 亚洲日本在线免费观看| 精品亚洲一区二区三区在线播放| 18禁成年无码免费网站无遮挡| 免费国产污网站在线观看| 337p日本欧洲亚洲大胆人人 | 亚洲国产综合久久天堂| 97在线线免费观看视频在线观看| 成人A毛片免费观看网站| 蜜桃传媒一区二区亚洲AV| 亚洲a级成人片在线观看| 亚洲爆乳无码一区二区三区| 亚洲精品国产高清嫩草影院| 免费看美女让人桶尿口| 日韩国产免费一区二区三区| 午夜理伦剧场免费| 中文字幕一区二区免费| 亚洲免费视频一区二区三区| 美女啪啪网站又黄又免费| 亚洲成_人网站图片|