亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

把WebLogic EJB程序遷移到JBoss上

2020-07-27 21:45:02
字體:
來源:轉載
供稿:網友

  WebLogic服務器是一款頂級的商業應用程序服務器。但是對于小規模的開發者來說,開發源代碼的、基于標準的應用程序服務器JBoss是可以用來替換類似WebLogic或WebSphere等商業應用程序服務器的。不幸的是,在WebLogic中開發的應用程序不能在JBoss中部署。JBoss遷移服務為我們提供了把應用程序遷移到JBoss上的支持。作為代替,通過把廠商特定的部署文件信息遷移到JBoss上,是可能把應用程序遷移到JBoss上的。為了演示如何把應用程序遷移到JBoss的過程,我們將把一個在WebLogic中開發的帶有Oracle數據庫的EJB應用程序遷移到帶有MySQL數據庫的JBoss應用程序服務器上。

  預安裝軟件

  為了配置MySQL數據庫的JDBC連接,需要下載MySQL數據庫驅動程序類。

  1.下載MySQL JDBC驅動程序.jar文件

  2.下載和安裝MySQL數據庫服務器

  3.下載和安裝JBoss 4.0應用程序服務器

  開發一個Java應用程序,我們將使用它和XSLT把WebLogic部署文件轉換為JBoss部署文件。該部署文件也可以使用XSLT工具進行轉換。

  概述

  在不進行修改的時候,WebLogic中開發的應用程序是不能部署在JBoss中的。JBoss應用程序的部署文件與WebLogic的部署文件不同。在本文中,我們將把一個在WebLogic中開發的實體(entity)EJB應用程序示例遷移到JBoss中,遷移的方法是把WebLogic部署文件轉換為JBoss部署文件。

  示例應用程序包含一個Catalog實體EJB。該EJB的bean類(CatalogBean.java)、遠程接口(Catalog.java)、和home接口(CatalogHome.java)都在本文下載鏈接的weblogic-jboss-resources.zip示例文件中。我們將使用MySQL開放源代碼數據庫來配置JBoss應用程序。把WebLogic EJB應用程序部署到JBoss中并不需要修改實體EJB類,只需要修改該EJB的部署文件。

  配置JBoss和MySQL

  MySQL是一個開放源代碼的數據庫,它適合于開放源代碼的項目和小型組織。為了配置JBoss和MySQL數據庫需要進行下面一些修改。

  配置JBoss類路徑

  為了使用JBoss 4.0和MySQL,我們首先要把驅動程序類.jar文件(mysql-connector-java-3.0.9-stable-bin.jar)復制到<JBoss>/server/default/lib目錄中。其中的<JBoss>是JBoss應用程序服務器安裝的目錄。lib目錄的.jar和.zip文件都包含在JBoss服務器的Classpath(類路徑)中。

  配置MySQL數據源

  為了使用MySQL數據源,需要把<JBoss>/docs/examples/jca/mysql-ds.xml復制到<JBoss>/server/default/deploy目錄中。當JBoss服務器啟動的時候,deploy目錄中的數據源配置文件就被部署好了。依照下面的步驟修改mysql-ds.xml配置文件:

  ? 把<driver-class/>設置為com.mysql.jdbc.Driver,<connection-url/>設置為jdbc:mysql://localhost/<database>,其中<database>是MySQL數據庫。<database>的值可以設置為test,它是MySQL中的示例數據庫。

  ? 在jndi-name元素中指定數據源的JNDI名稱。

  ? 指定連接MySQL數據庫的用戶名和密碼。在默認情況下,root用戶名不需要密碼。

  ? 把type-mapping元素指定為mySQL。type-mapping元素指定了standardjbosscmp-jdbc.xml部署文件中預定義的數據庫類型映射關系。對于MySQL數據庫來說,類型映射是mySQL。

  修改過的mysql-ds.xml如下所示:

 ?。?xml version="1.0" encoding="UTF-8"?>
 ?。糳atasources>
 ?。糽ocal-tx-datasource>
 ?。糺ndi-name>MySqlDS</jndi-name>
  <connection-url>jdbc:mysql://localhost/test</connection-url>
 ?。糳river-class>com.mysql.jdbc.Driver</driver-class>
  <user-name>root</user-name>
 ?。紁assword></password>
 ?。糾etadata>
 ?。紅ype-mapping>mySQL</type-mapping>
  </metadata>
 ?。?local-tx-datasource>
  </datasources>

  我們可以通過提供數據源JNDI名稱從數據源獲取一個JDBC連接:

  InitialContext initialContext = new InitialContext();
  javax.sql.DataSource ds = (javax.sql.DataSource)
  initialContext.lookup("java:/MySqlDS");
  java.sql.Connection conn = ds.getConnection();

  配置登錄信息

  現在我們根據MySQL數據庫設置來修改login-config.xml配置文件。為了登錄到MySQL數據庫,應用程序策略MySqlDbRealm是必要的。給login-config.xml添加下面的<application-policy/>元素:

 ?。糰pplication-policy name = "MySqlDbRealm">
  <authentication>
 ?。糽ogin-module code =
  "org.jboss.resource.security.ConfiguredIdentityLoginModule"
  flag = "required">
 ?。糾odule-option name ="principal"></module-option>
 ?。糾odule-option name ="userName">root</module-option>
 ?。糾odule-option name ="password"></module-option>
  <module-option name ="managedConnectionFactoryName">
  jboss.jca:service=LocalTxCM,name=MySqlDS
 ?。?module-option>
 ?。?login-module>
 ?。?authentication>
 ?。?application-policy>


  通過修改mysql-ds.xml和login-config.xml文件,JBoss 4.0服務器已經被配置好了,可以使用MySQL數據庫了。除了前面的一些特定的設置之外,可能還需要對JBoss部署文件和JBoss JDBC配置文件作一些修改。

  如果"建立表"選項被選中(通過把jbosscmp-jdbc.xml中的create-table元素設置為true)用于部署CMP實體EJB,并且MySQL表的主鍵(或唯一鍵)的長度超過了500字節,應用程序的部署過程會在MySQL數據庫中生成一個SQL語法錯誤。對于java.lang.String類型的CMP字段,我們可以通過在standardjbosscmp-jdbc.xml部署文件的mySQL類型映射中把用于Java類型java.lang.String的SQL類型設置為較低的VARCHAR值來減小主鍵(或唯一鍵)的長度。另一個可能出現的問題是jbosscmp-jdbc.xml部署文件中的column-name元素。如果某個MySQL表的列名與MySQL保留字相同,在JBoss中部署J2EE應用程序的時候會產生一個錯誤。解決這個問題的方法是使列名與MySQL保留字不同。

   轉換WebLogic EJB應用程序

  在建立起使用MySQL的JBoss服務器之后,你現在必須把該WebLogic EJB應用程序轉換為JBoss EJB應用程序,這就涉及到部署文件的修改。WebLogic實體EJB應用程序由EJB部署文件(ejb-jar.xml、weblogic-ejb-jar.xml和weblogic-cmp-rdbms-jar.xml),bean類(CatalogBean.java)、遠程接口(Catalog.java)和home接口(CatalogHome.java)組成。為了在WebLogic服務器上部署實體EJB,需要建立一個EJB .jar文件,這個EJB .jar文件的結構如下:

  META-INF/
  ejb-jar.xml
  weblogic-ejb-jar.xml
  weblogic-cmp-rdbms-jar.xml
  CatalogBean.class
  Catalog.class
  CatalogHome.class

  EJB的結構信息和應用程序匯編信息都在部署文件中指定。結構信息包括說明EJB是對話EJB還是實體EJB。ejb-jar.xml部署文件中的應用程序匯編信息在assembly-descriptor元素中指定。WebLogic中該實體EJB部署文件包括ejb-jar.xml、weblogic-ejb-jar.xml和weblogic-cmp-rdbms-jar.xml。相應的JBoss部署文件是ejb-jar.xml、jboss.xml和jbosscmp-jdbc.xml。這些文件之間的轉換如下所示。

  ejb-jar.xml部署文件對于WebLogic和JBoss來說都是一樣的,除了multiplicity元素之外。JBoss服務器的ejb-jar.xml中的multiplicity元素需要大寫,例如One或Many,而不是one或many。

  示例實體EJB的ejb-jar.xml部署文件包含在示例代碼中。示例ejb-jar.xml定義了一個叫做"Catalog"的實體EJB。這個示例EJB擁有CMP字段catalogId、journal和publisher。其主鍵字段是catalogId。

  把weblogic-ejb-jar.xml轉換為jboss.xml

  weblogic-ejb-jar.xml和jboss.xml部署文件都是EJB廠商的特定部署文件。為了把WebLogic EJB應用程序部署到JBoss應用程序服務器上,必須把weblogic-ejb-jar.xml部署文件轉換為jboss.xml。

  weblogic-ejb-jar.xml中的根元素是weblogic-ejb-jar。jboss.xml中的根元素是jboss。在jboss.xml和weblogic-ejb-jar.xml部署文件中指定某個EJB的JNDI名稱的元素是jndi-name或local-jndi-name。本文中的示例實體EJB的weblogic-ejb-jar.xml部署文件也包含在示例代碼中。weblogic-ejb-jar.xml部署文件的DOCTYPE元素是:

 ?。?DOCTYPE weblogic-ejb-jar PUBLIC
  "-//BEA Systems, Inc.//DTD WebLogic 8.1.0 EJB//EN"
  "http://www.bea.com/servers/wls810/dtd/weblogic-ejb-jar.dtd" >
  jboss.xml部署文件的DOCTYPE是:
 ?。?DOCTYPE jboss PUBLIC "-//JBoss//DTD JBOSS 4.0//EN"
  "http://www.jboss.org/j2ee/dtd/jboss_4_0.dtd">

  我們通過一個自定義的XSLT樣式表jboss.xslt(包含在示例代碼中)把部署文件weblogic-ejb-jar.xml轉換為jboss.xml。該樣式表建立jboss.xml,它是與WebLogic的weblogic-ejb-jar.xml部署文件相當的JBoss文件。使用jboss.xslt樣式表所生成的jboss.xml文件也包含在示例代碼中。

  把weblogic-cmp-rdbms-jar.xml轉換為jbosscmp-jdbc.xml

  weblogic-cmp-rdbms-jar.xml部署文件指定了CMP實體EJB的數據庫持續信息。weblogic-cmp-rdbms-jar.xml文件包含實體EJB的表名稱、連接到數據庫的數據源和與該實體EJB CMP字段對應的列。示例實體EJB的weblogic-cmp-rdbms-jar.xml部署文件包含在可以下載的.zip文件中。指定CMP視圖EJB持續信息的JBoss部署文件是jbosscmp-jdbc.xml。

  weblogic-cmp-rdbms-jar.xml的根元素是weblogic-rdbms-jar;jbosscmp-jdbc.xml的根元素是jbosscmp-jdbc。weblogic-cmp-rdbms-jar.xml文件中指定連接到數據庫的數據源的data-source-name元素與jbosscmp-jdbc.xml部署文件中的datasource元素功能相當。weblogic-cmp-rdbms-jar.xml指定實體EJB CMP字段與數據庫表的列之間映射關系的field-map元素與jbosscmp-jdbc.xml中的cmp-field元素功能相當。weblogic-cmp-rdbms-jar.xml中指定列名的dbms-column元素與jbosscmp-jdbc.xml中的column-name元素功能相當。weblogic-cmp-rdbms-jar.xml部署文件的DOCTYPE是:

 ?。?DOCTYPE weblogic-rdbms-jar PUBLIC
  '-//BEA Systems, Inc.//DTD WebLogic 8.1.0 EJB RDBMS Persistence//EN'
  'http://www.bea.com/servers/wls810/dtd/weblogic-rdbms20-persistence-810.dtd'>
  jbosscmp-jdbc.xml的DOCTYPE是:
  <!DOCTYPE jbosscmp-jdbc PUBLIC "-//JBoss//DTD JBOSSCMP-JDBC 4.0//EN"
  "http://www.jboss.org/j2ee/dtd/jbosscmp-jdbc_4_0.dtd">


  我們使用自定義的XSLT樣式表jbosscmp-jdbc.xslt(包含在示例代碼中)把部署文件weblogic-cmp-rdbms-jar.xml轉換為jbosscmp-jdbc.xml。該樣式表建立jbosscmp-jdbc.xml,它是與WebLogic的weblogic-cmp-rdbms-jar.xml部署文件功能相當的JBoss文件。jbosscmp-jdbc.xml也包含下載在.zip文件中。

  WebLogic部署文件的DTD與JBoss部署文件的不同。使用自定義的XSLT的時候,如果部署文件中還出現了一些額外的元素,可能還需要做進一步的修改,可以把WebLogic部署文件轉換為JBoss部署文件。在下面的部分中,我們將在JBoss服務器上部署這個EJB應用程序。

  在JBoss中部署該EJB應用程序

  把WebLogic EJB部署文件轉換為JBoss部署文件之后,你必須建立一個心的EJB .jar文件以部署到JBoss服務器上。該JBoss .jar文件的結構如下:

  META-INF/
  ejb-jar.xml
  jboss.xml
  jbosscmp-jdbc.xml
  CatalogBean.class
  Catalog.class
  CatalogHome.class

  編譯示例EJB類和接口:

  java Catalog.java CatalogBean.java CatalogHome.java

  把JBoss部署文件ejb-jar.xml、jboss.xml和jbosscmp-jdbc.xml復制到META-INF目錄中。使用jar工具從JBoss部署文件、類和接口中建立一個.jar文件。

  jar cf CatalogEJB.jar CatalogBean.class
  Catalog.class CatalogHome.class META-INF/*.xml

  部署該JBoss實體EJB應用程序的過程是,把該.jar文件(EntityEJB.jar)復制到<JBoss>/server/default/deploy目錄(其中<JBoss>是JBoss安裝的目錄)中。當服務器啟動的時候,該EJB應用程序就在JBoss服務器上面部署好了。JBoss應用程序服務器中的部署(deploy)目錄與WebLogic應用程序服務器中的應用程序(applications)目錄對應。

  結論

  通過轉換部署文件可以把WebLogic中部署的實體EJB應用程序遷移到JBoss應用程序服務器上。使用相似的步驟,通過把weblogic.xml 部署文件轉換為jboss-web.xml ,也可以把WebLogic J2EE Web應用程序遷移到JBoss上。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产中文字幕久久网| 久久影院在线观看| 欧美激情中文字幕在线| 国产va免费精品高清在线观看| 亚洲视频777| 亚洲欧美中文日韩v在线观看| 亚洲欧洲国产精品| 成人国产精品一区二区| 欧美另类在线观看| 日韩视频欧美视频| 亚洲韩国日本中文字幕| 国产精品视频内| 欧美激情一区二区三区久久久| 国产精品对白刺激| 国产日韩在线看片| 精品无码久久久久久国产| 亚洲片在线资源| 美女久久久久久久| 欧美电影免费观看高清完整| 91精品国产91久久久| 中文字幕av一区二区| 亚洲va欧美va国产综合剧情| 国产精品观看在线亚洲人成网| 国产精品九九九| 欧美一级成年大片在线观看| 久久精品电影一区二区| 亚洲欧美日韩第一区| 激情成人中文字幕| 欧美视频13p| 国产97在线视频| 国产精品日韩欧美综合| 亚洲人线精品午夜| 国产精品高潮呻吟久久av野狼| 国产精品一香蕉国产线看观看| 亚洲国产精品免费| 国产精品手机播放| 福利视频一区二区| 国产亚洲a∨片在线观看| 91久久精品国产91性色| 亚洲成人精品视频在线观看| 亚洲精品免费一区二区三区| 91精品免费看| 成人免费淫片aa视频免费| 97超级碰碰碰| 在线观看日韩专区| 久久久久久国产精品三级玉女聊斋| 国产成人aa精品一区在线播放| 国产精品男人的天堂| 少妇久久久久久| 在线播放国产精品| 国产亚洲精品91在线| 欧美高清在线视频观看不卡| 欧美午夜精品久久久久久浪潮| 九九精品在线播放| 日韩中文第一页| 2024亚洲男人天堂| 91中文字幕在线| 国产成人精彩在线视频九色| 欧美精品手机在线| 久久成人18免费网站| 国模精品一区二区三区色天香| 久久亚洲私人国产精品va| 日韩成人在线视频| 亚洲a成v人在线观看| 欧美日韩国产中字| 欧美日韩国产成人在线| 91在线免费看网站| 国产精品一区二区三区毛片淫片| 2024亚洲男人天堂| 超在线视频97| 国产在线98福利播放视频| 精品色蜜蜜精品视频在线观看| 国外成人免费在线播放| 久久夜色精品国产亚洲aⅴ| 91精品国产免费久久久久久| 国产欧美一区二区三区视频| 欧洲永久精品大片ww免费漫画| 久久99久国产精品黄毛片入口| 亚洲欧美日韩久久久久久| 欧美精品在线网站| 免费91麻豆精品国产自产在线观看| 亚洲天堂av在线免费| 精品日韩美女的视频高清| 亚洲无限av看| 亚洲福利在线看| 日韩av在线免费播放| 欧美午夜影院在线视频| 欧美二区乱c黑人| 亚洲欧美在线一区| 亚洲韩国日本中文字幕| 成人午夜两性视频| 国产精品视频白浆免费视频| 中文字幕精品国产| 在线观看久久久久久| 韩日精品中文字幕| 精品久久久久久久久久久久久久| 性欧美长视频免费观看不卡| 亚洲视频在线播放| 91精品国产777在线观看| 精品久久久久久久久久久久| 国模私拍一区二区三区| 一区二区三区视频在线| 久久精品在线播放| 亚洲免费人成在线视频观看| 国产成人在线亚洲欧美| 日韩亚洲综合在线| 久久亚洲欧美日韩精品专区| 日韩国产在线播放| 97在线视频国产| 91精品国产高清久久久久久| 成人黄色影片在线| 国产精品主播视频| 青青草99啪国产免费| 久久福利视频导航| 国产精品久久久久一区二区| 国产精品久久久久久久av大片| 热门国产精品亚洲第一区在线| 精品国产拍在线观看| 国产精品电影在线观看| 成人午夜在线观看| 992tv成人免费影院| 亚洲男人的天堂在线播放| 日韩精品久久久久久久玫瑰园| 国产精品电影一区| 成人免费在线视频网址| 国产成人一区三区| 欧美精品999| 福利一区视频在线观看| 亚洲网站在线播放| 人体精品一二三区| 亚洲精品视频播放| 国产精品免费一区豆花| 欧美韩日一区二区| 国产综合在线观看视频| 久久久久久91香蕉国产| 午夜精品久久久久久99热| 中文字幕日韩欧美| 欧美性生交大片免网| 久久人人爽人人| 成人a免费视频| 中文字幕日韩精品在线观看| 日本精品视频在线播放| 亚洲精品成a人在线观看| 亚洲福利在线播放| 国产欧美va欧美va香蕉在| 91久久国产综合久久91精品网站| 粗暴蹂躏中文一区二区三区| 国产精品第1页| 中文字幕精品网| 按摩亚洲人久久| 亚洲最大福利网| 91九色在线视频| 91亚洲精品一区二区| 日韩在线视频观看正片免费网站| 久久久久久久国产精品| 日本aⅴ大伊香蕉精品视频| 日韩在线观看免费高清| 国产精品福利在线| 亚洲欧洲日产国产网站| 欧美在线xxx| 91美女福利视频高清| 亚洲激情免费观看| 美女精品视频一区| 亚洲国产欧美精品|