<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      基于weblogic 的EJB 學習筆記

      [摘要]EJB 學習筆記1、ejb 基礎知識(1) 無狀態會話bean不保存客戶機的會話狀態優點:使用小量的實例即可滿足大量的客戶。每個實例都沒有標識,相互之間是等價的。等冪的無狀態會話bean:多次和一次...
      EJB 學習筆記
      1、ejb 基礎知識
      (1) 無狀態會話bean
      不保存客戶機的會話狀態
      優點:使用小量的實例即可滿足大量的客戶。每個實例都沒有標識,相互之間是等價的。
      等冪的無狀態會話bean:多次和一次調用的結果和效應相同。
      在集群中可以負載均衡 a 機器失敗,可以在b機器上重試
      非等冪的無狀態會話bean: 如:計數器
      不能自動因故障而進行切換。
      (2) 有狀態會話bean
      保存客戶機的會話狀態
      特點: 在有會話狀態會話的bean例子中,出納員的數量等于活動的顧客的數量,這可以簡化編程模式
      weblogic 通過內存復制技術 在集群中進行負載均衡
      內存復制技術: 每個有會話狀態的bean實例都將存儲在兩個服務器的內存中,一個服務器作為主服務器,另一個作為輔助服務器。
       如果主失敗,輔助變為主,然后自動選擇別的可用的服務器作為輔助。
      遺憾: 很難在servlet 和jsp中用好有狀態會話bean?赡軙l生并發現象,產生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 引用?梢允褂肏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);

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

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


      日韩精品一区二区三区高清