国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

部署基于JBoss的J2EE應(yīng)用程序

2019-11-18 11:36:08
字體:
供稿:網(wǎng)友

  JBoss,作為J2EE應(yīng)用服務(wù)器,以其EJB容器卓越的性能、技術(shù)的潮流性、開發(fā)部署J2EE應(yīng)用的方便性贏得了很多J2EE開發(fā)者的信賴。其中,免安裝、基于JMX構(gòu)架、熱部署(Hot Deploy)、快速開發(fā)EJB應(yīng)用等幾項特征與其他商用服務(wù)器相比,顯得有些自得忘形的樣子。盡管其本身沒有重大的缺陷,但究竟是Open Source的開發(fā)模式,文檔很少,因此要很好的把握、精通開發(fā)基于JBoss的應(yīng)用還是顯得有些力不從心。
  
  本文結(jié)合作者的開發(fā)經(jīng)驗,給出在JBoss 3.2.1下開發(fā)J2EE的一些很實用的相關(guān)的注重事項和規(guī)則。其中,讀者一定要知道JBoss 3.2.1作為JBoss的過渡產(chǎn)品(與JBoss 3.0.x、JBoss 4.x相比),自然有些東西和JBoss 3.0.x、JBoss 4.x有很大差別。但是,一般情況下,本文介紹的內(nèi)容,大體上都適合JBoss各個版本。
  
  下載完JBoss 3.2.1后,解壓到一個沒有空格的目錄路徑下面就可以運行JBoss,所以很方便,但前提是目標機器安裝了java 2 Standard Edition。一切就緒后,我們就開始吧。(假設(shè)JBoss 3.2.1安裝在:C:/jboss-3.2.1_tomcat-4.1.24,本使用default配置)
  
  一、相關(guān)配置文件的設(shè)置
  
  為開發(fā)J2EE應(yīng)用,操作數(shù)據(jù)庫成了必不可少的內(nèi)容;調(diào)節(jié)日志輸出的具體程度成了調(diào)試J2EE應(yīng)用的要害;EJB應(yīng)用的調(diào)優(yōu)過程是J2EE應(yīng)用的核心。
  
  1. 數(shù)據(jù)源的配置:
  
  在JBoss 3.2.1中,配置數(shù)據(jù)源的步驟很簡單,JBoss 3.2.1本身帶了主流數(shù)據(jù)庫的配置實例,于目錄下:C:/jboss-3.2.1_tomcat-4.1.24/docs/examples/jca。具體使用哪個配置文件取決于目標用戶的數(shù)據(jù)庫。假如是SQL Server 2000,則需要使用MSSQL-ds.xml文件(支持本地事務(wù))或者mssql-xa-ds.xml文件(支持全局事務(wù));假如是Oracle 9i數(shù)據(jù)庫,則需要使用oracle-ds.xml文件或者oracle-xa-ds.xml文件等。這里以SQL Server 2000為例。
  
  首先將mssql-ds.xml文件拷貝到目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/deploy下。然后打開文件,并作如下修改:
  
  <datasources>
  <local-tx-datasource>
  <jndi-name>VSSDB</jndi-name>
  <connection-url>jdbc:microsoft:sqlserver://125.16.45.158:1433;DatabaseName=DDD
  </connection-url>
  <driver-class>com.microsoft.jdbc.sqlserver.SQLServerDriver</driver-class>
  <user-name>sa</user-name>
  <passWord>sa</password>
  <min-pool-size>50</min-pool-size>
  <max-pool-size>200</max-pool-size>
  </local-tx-datasource>
  </datasources>
  
  假如目標J2EE應(yīng)用只需要本地事務(wù),則上述過程已經(jīng)完成了Datasource的配置,同時這個配置將用于JDBC以及EJB通過JNDI使用。假如要實現(xiàn)EJB使用Datasource,則還需要修改位于目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/conf下的standardjbosscmp-jdbc.xml文件。比如:
  
  <jbosscmp-jdbc>
  
  <defaults>
  <datasource>java:/VSSDB1</datasource>
  <datasource-mapping>MS SQLSERVER2000</datasource-mapping>
  
  <create-table>true</create-table>
  <remove-table>false</remove-table>
  <read-only>false</read-only>
  <time-out>300</time-out>
  <pk-constraint>true</pk-constraint>
  <fk-constraint>false</fk-constraint>
  
  其中,java:/VSSDB中的VSSDB就是mssql-ds.xml配置的數(shù)據(jù)源;而“java:/”前綴表明該命名空間只是對JBoss本身可見,即運行于JBoss外的應(yīng)用是不能夠使用這里定義的數(shù)據(jù)源,這一點希望注重。
  
  其次,MS SQLSERVER2000中的MS SQLSERVER2000可以在該文件的其他地方找到。(假如是其他數(shù)據(jù)庫,情況都是類似的)
  
  2. 日志的輸出具體程度配置:
  
  由于JBoss 3.2.1開發(fā)采用了Log4j治理其日志信息(嚴格地講,它擴展了Log4j),因此了解Log4j的機理,有助于理解JBoss 3.2.1治理日志的方式。JBoss 3.2.1采用JMX架構(gòu)的同時,且以.xml文件類型為配置文件,因此可以找到位于目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/conf下的log4j.xml文件。比如,其中一段配置示例如下:
  
  <appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
  <param name="Target" value="System.out"/>
  <param name="Threshold" value="INFO"/>
  
  <layout class="org.apache.log4j.PatternLayout">
  <!-- The default pattern: Date Priority [Category] Message/n -->
  <param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
  </layout>
  </appender>
  
  比如,為了調(diào)節(jié)JBoss 3.2.1控制臺日志輸出的具體程度(調(diào)整為DEBUG級別),我們需要修改value=”INFO”,將INFO改為DEBUG。 假如開發(fā)Entity Beans,可以調(diào)節(jié)位于與log4j.xml文件同一目錄下的standardjboss.xml文件(該文件主要是提供修改EJB相關(guān)的調(diào)試、運行、調(diào)優(yōu)、部署參數(shù))。假如Entity Beans采用的為Standard CMP 2.x EntityBean,則將其中的屬性的取值改為true。
  
  <container-configuration>
  <container-name>Standard CMP 2.x EntityBean</container-name>
  <call-logging>false</call-logging>
  <invoker-proxy-binding-name>entity-rmi-invoker</invoker-proxy-binding-name>
  <sync-on-commit-only>false</sync-on-commit-only>
  
  完成上述兩步后,在調(diào)試Entity Beans時通過控制臺,可以看到Entity Beans發(fā)出的JDBC調(diào)用細節(jié)。
  
  3. Tomcat容器相關(guān)參數(shù)的配置:
  
  假如使用JBoss 3.2.1與Tomcat 4.1.24的集成版本,則可以通過調(diào)節(jié)分別位于目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/deploy/jbossweb-tomcat.sar下的web.xml和目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/deploy/jbossweb-tomcat.sar/META-INF下的jboss-service.xml文件來達到目標讀者特定需求。比如,假如想將HTTP服務(wù)端口改為80,則可以修改jboss-service.xml文件;假如想使目標J2EE應(yīng)用處理更多的文件類型,可以修改web.xml文件。
  
  4. 相關(guān)類庫的放置:
  
  假如應(yīng)用涉及到第三方類庫,比如JDBC Driver,則可以將這些JDBC Driver存放到目錄下:C:/jboss-3.2.1_tomcat-4.1.24/server/default/lib。注重,不是目錄:C:/jboss-3.2.1_tomcat-4.1.24/lib下。
  
  假如是與目標J2EE應(yīng)用相關(guān),則可以存放到目標.war(或者.ear)里面,或者xxx.war目錄中的WEB-INFO/lib下。無論那種情形,都需要遵循J2EE規(guī)范。當然,JBoss 3.2.1的配置文件有很多,比如還有提供郵件服務(wù)的mail-service.xml文件等。
  
  二、開發(fā)EJB應(yīng)用
  
  假如開發(fā)EJB應(yīng)用,建議采用JBoss作為開發(fā)服務(wù)器,因為開發(fā)、調(diào)試、部署速度快。假如采用其他商用服務(wù)器,由于實現(xiàn)機理的不同,其編譯的速度很慢。假如采用Entity Beans技術(shù),則您需要知道這幾點。第一,您目標系統(tǒng)的數(shù)據(jù)源有多少個操作入口,即是否存在Entity Beans之外的方式來操作數(shù)據(jù)庫。假如有,則需要調(diào)節(jié)相應(yīng)的提交策略以及策略。
  
  比如,JBoss 3.2.1采用的方式有4種:A、B、C、D。當然,假如除了Entity Beans訪問數(shù)據(jù)庫外,別無它出,采用A是很理智的。假如有,則需要取決于具體的情況使用方式。同時,方式的選擇與策略有關(guān)系。能夠采用的Entity Beans或Entity Beans Methods,則盡量采用,這樣會減少或消除死鎖發(fā)生的可能性。盡量采用1:n的關(guān)系來操作n方的數(shù)據(jù)表結(jié)構(gòu),這樣能夠提高EJB Container的效率。
  
  一般情況下,J2EE應(yīng)用服務(wù)器支持JDBC事務(wù)、JTA事務(wù)、容器治理事務(wù)。同時,最好不要在程序中同時使用上述三種事務(wù)類型,比如在JTA事務(wù)中嵌套JDBC事務(wù);第二方面,事務(wù)要在盡可能短的時間內(nèi)完成,不要在不同方法中實現(xiàn)事務(wù)的使用。比如,下面給出了回滾JDBC事務(wù)的代碼示例:
  
  public void PRocessT(String orders) {
  Context initCtx = new InitialContext();
  javax.sql.DataSource ds = javax.sql.DataSource)initCtx.lookup
  (“java:comp/env/jdbc/OrdersDB”);
  java.sql.Connection conn = ds.getConnection();
  try{
  conn.setAutoCommit( false ); //更改JDBC事務(wù)的默認提交方式
  orderNo = createOrder( orders );
  updateOrderStatus(orderNo, “orders created”);
  conn.commit();//提交JDBC事務(wù)
  }catch( Exception e ){
  try{
  conn.rollback();//回滾sJDBC事務(wù)
  throw new EJBException(“事務(wù)回滾: “ + e.getMessage());
  }catch( SQLException sqle ){
  throw new EJBException(“出現(xiàn)SQL操作錯誤: “ + sqle.getMessage());
  }
  }
  }
  
  下面給出了JTA事務(wù)代碼示例:
  
  public void processOrder(String orderMessage) {
  UserTransaction transaction = mysessionContext.getUserTransaction();//獲得JTA事務(wù)
  try{
  transaction.begin();//開始JTA事務(wù)
  orderNo = sendOrder(orderMessage);
  updateOrderStatus(orderNo, “order sent”);
  transaction.commit();//提交JTA事務(wù)
  }catch(Exception e){
  try{
  transactio

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 德州市| 蒲江县| 陕西省| 新民市| 罗田县| 蓝山县| 方正县| 西盟| 布尔津县| 连州市| 永善县| 镇雄县| 阳朔县| 乳山市| 达拉特旗| 大宁县| 龙里县| 社旗县| 手游| 灌南县| 河南省| 林芝县| 毕节市| 阜城县| 双峰县| 特克斯县| 金阳县| 翁牛特旗| 荆门市| 兴化市| 卢龙县| 中宁县| 正镶白旗| 新宾| 仲巴县| 讷河市| 长兴县| 龙山县| 石台县| 石台县| 西藏|