開發基於JBoss的J2EE應用

JBoss,作爲J2EE應用服務器,以其EJB容器卓越的性能、技術的潮流性、開發部署J2EE應用的方便性贏得了很多J2EE開發者的信賴。其中,免安裝、基於JMX構架、熱部署(Hot Deploy)、快速開發EJB應用等幾項特徵與其他商用服務器相比,顯得有些得饌蔚難印>」芷潯舊礱揮兄卮蟮娜畢藎暇故荗pen Source的開發模式,文檔很少,因此要很好的掌握、精通開發基於JBoss的應用還是顯得有些力不從心。
本文結合自己的開發經驗,給出在JBoss 3.2.1下開發J2EE一些相關的注意事項和規則。其中,讀者一定要知道JBoss 3.2.1作爲JBoss的過渡產品(與JBoss 3.0.x、JBoss 4.x相比),自然有些東西和JBoss 3.0.x、JBoss 4.x有很大差別。但是,一般情況下,本文介紹的內容,大體上都適合JBoss各個版本。
下載完JBoss 3.2.1後,解壓到一個沒有空格的目錄路徑下面就可以運行JBoss,所以很方便,但前提是目標機器安裝了Java 2 Standard Edition。一切就緒後,開始我們的旅程。
(假設JBoss 3.2.1安裝在:C:/jboss-3.2.1_tomcat-4.1.24,本使用default配置)
一,    相關配置文件的設置
爲開發J2EE應用,操作數據庫成了必不可少的內容;調節日誌輸出的詳細程度成了調試J2EE應用的關鍵;EJB應用的調優過程是J2EE應用的核心。等等,這些內容都是我們需要知道的。

(1)數據源的配置:

在JBoss 3.2.1中,配置數據源的步驟很簡單,JBoss 3.2.1本身帶了主流數據庫的配置實例,於目錄下:C:/jboss-3.2.1_tomcat-4.1.24/docs/examples/jca。具體使用那個配置文件取決於目標用戶的數據庫。如果是SQL Server 2000,則需要使用mssql-ds.xml文件(支持本地事務)或者mssql-xa-ds.xml文件(支持全局事務);如果是Oracle 9i數據庫,則需要使用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
        < connection-url>jdbc:microsoft:sqlserver://125.16.45.158:1433;DatabaseName=DDD
< /connection-url>
        < driver-class>com.microsoft.jdbc.sqlserver.SQLServerDriver
        < user-name>sa
        < password>sa
        < min-pool-size>50
        < max-pool-size>200
    < /local-tx-datasource>
< /datasources>
如果目標J2EE應用只需要本地事務,則上述過程已經完成了Datasource的配置,同時這個配置將用於JDBC以及EJB通過JNDI使用。如果要實現EJB使用Datasource,則還需要修改位於目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/conf下的standardjbosscmp-jdbc.xml文件。比如,
< jbosscmp-jdbc>

   < defaults>
      < datasource>java:/VSSDB1
      < datasource-mapping>MS SQLSERVER2000

      < create-table>true
      < remove-table>false
      < read-only>false
      < time-out>300
      < pk-constraint>true
      < fk-constraint>false
。。。。。。。。
其中,java:/VSSDB中的VSSDB就是mssql-ds.xml配置的數據源;而“java:/”前綴表明該命名空間只是對JBoss本身可見,即運行於JBoss外的應用是不能夠使用這裏定義的數據源,這一點希望讀者注意。
其次,MS SQLSERVER2000中的MS SQLSERVER2000可以在該文件的其他地方找到。(如果是其他數據庫,情況都是類似的,希望讀者加以思考!)

(2)日誌的輸出詳細程度配置:
    
由於JBoss 3.2.1開發採用了Log4j管理其日誌信息(嚴格地講,它擴展了Log4j),因此瞭解Log4j的機理,有助於理解JBoss 3.2.1管理日誌的方式。
JBoss 3.2.1採用JMX架構的同時,且以.xml文件類型爲配置文件,因此可以找到位於目錄:C:/jboss-3.2.1_tomcat-4.1.24/server/default/conf下的log4j.xml文件。比如,其中一段配置示例如下:
      
    < 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>
比如,爲了調節JBoss 3.2.1控制檯日誌輸出的詳細程度(調整爲DEBUG級別),我們需要修改value=”INFO”,將INFO改爲DEBUG。
如果目標讀者在開發Entity Beans,可以調節位於與log4j.xml文件同一目錄下的standardjboss.xml文件(該文件主要是提供修改EJB相關的調試、運行、調優、部署參數)。如果目標讀者Entity Beans採用的< container-name>爲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>
。。。。。。。。。
完成上述兩步後,讀者在調試Entity Beans時通過控制檯,可以看到Entity Beans發出的JDBC調用細節。

(3)Tomcat容器相關參數的配置:

如果目標讀者使用JBoss 3.2.1與Tomcat 4.1.24的集成版本,則可以通過調節分別位於目錄: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服務端口改爲80,則可以修改jboss-service.xml文件;如果想使目標J2EE應用處理更多的文件類型,可以修改web.xml文件。

(4)相關類庫的放置:

如果您的應用涉及到第三方類庫,比如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應用相關,則可以存放到目標.war(或者.ear)裏面,或者xxx.war目錄中的WEB-INFO/lib下。無論那種情形,都需要遵循J2EE規範。

當然,JBoss 3.2.1的配置文件有很多,比如提供郵件服務的mail-service.xml文件,等等。在這裏只是給讀者一些信息,如果您有相關問題,都可以試着本文介紹的一些內容解決您的問題。謝謝。

二,開發EJB應用
如果開發EJB應用,建議採用JBoss作爲開發服務器,因爲開發、調試、部署速度快。如果採用其他商用服務器,由於實現機理的不同,其編譯的速度很慢。
如果採用Entity Beans技術,則您需要知道這麼幾點。第一,您目標系統的數據源有多少個操作入口,即是否存在Entity Beans之外的方式來操作數據庫。如果有,則需要調節相應< container-name>的< commit-option>提交策略以及< locking-policy>策略。
比如,JBoss 3.2.1採用的< commit-option>方式有4種:A、B、C、D。當然,如果除了Entity Beans訪問數據庫外,別無它出,採用A是很理智的。如果有,則需要取決於具體的情況使用< commit-option>方式。同時,方式的選擇與< locking-policy>策略有關係。
能夠採用的Entity Beans或Entity Beans Methods,則儘量採用,這樣會減少或消除死鎖發生的可能性。
儘量採用1:n的關係來操作n方的數據表結構,這樣能夠提高EJB Container的效率。
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章