|
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,所以很方便,但前提是目標(biāo)機器安裝了Java 2 Standard Edition。一切就緒后,開始我們的旅程。 (假設(shè)JBoss 3.2.1安裝在:C:\jboss-3.2.1_tomcat-4.1.24,本使用default配置) 一,相關(guān)配置文件的設(shè)置 (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。具體使用那個配置文件取決于目標(biāo)用戶的數(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> 如果目標(biāo)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:/VSSDB</datasource>中的VSSDB就是mssql-ds.xml配置的數(shù)據(jù)源;而“java:/”前綴表明該命名空間只是對JBoss本身可見,即運行于JBoss外的應(yīng)用是不能夠使用這里定義的數(shù)據(jù)源,這一點希望讀者注意。 其次,<datasource-mapping>MS SQLSERVER2000</datasource-mapping>中的MS SQLSERVER2000可以在該文件的其他地方找到。(如果是其他數(shù)據(jù)庫,情況都是類似的,希望讀者加以思考!) (2)日志的輸出詳細(xì)程度配置: 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"> 比如,為了調(diào)節(jié)JBoss 3.2.1控制臺日志輸出的詳細(xì)程度(調(diào)整為DEBUG級別),我們需要修改value=”INFO”,將INFO改為DEBUG。 如果目標(biāo)讀者在開發(fā)Entity Beans,可以調(diào)節(jié)位于與log4j.xml文件同一目錄下的standardjboss.xml文件(該文件主要是提供修改EJB相關(guān)的調(diào)試、運行、調(diào)優(yōu)、部署參數(shù))。如果目標(biāo)讀者Entity Beans采用的<container-name>為Standard CMP 2.x EntityBean,則將其中的<call-logging>屬性的取值改為true。 <container-configuration> 完成上述兩步后,讀者在調(diào)試Entity Beans時通過控制臺,可以看到Entity Beans發(fā)出的JDBC調(diào)用細(xì)節(jié)。 (3)Tomcat容器相關(guān)參數(shù)的配置: 如果目標(biāo)讀者使用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文件來達(dá)到目標(biāo)讀者特定需求。 比如,如果想將HTTP服務(wù)端口改為80,則可以修改jboss-service.xml文件;如果想使目標(biāo)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下。 如果是與目標(biāo)J2EE應(yīng)用相關(guān),則可以存放到目標(biāo).war(或者.ear)里面,或者xxx.war目錄中的WEB-INFO\lib下。無論那種情形,都需要遵循J2EE規(guī)范。 當(dāng)然,JBoss 3.2.1的配置文件有很多,比如提供郵件服務(wù)的mail-service.xml文件,等等。在這里只是給讀者一些信息,如果您有相關(guān)問題,都可以試著本文介紹的一些內(nèi)容解決您的問題。謝謝。 二,開發(fā)EJB應(yīng)用 如果開發(fā)EJB應(yīng)用,建議采用JBoss作為開發(fā)服務(wù)器,因為開發(fā)、調(diào)試、部署速度快。如果采用其他商用服務(wù)器,由于實現(xiàn)機理的不同,其編譯的速度很慢。 如果采用Entity Beans技術(shù),則您需要知道這么幾點。第一,您目標(biāo)系統(tǒng)的數(shù)據(jù)源有多少個操作入口,即是否存在Entity Beans之外的方式來操作數(shù)據(jù)庫。如果有,則需要調(diào)節(jié)相應(yīng)<container-name>的<commit-option>提交策略以及<locking-policy>策略。 比如,JBoss 3.2.1采用的<commit-option>方式有4種:A、B、C、D。當(dāng)然,如果除了Entity Beans訪問數(shù)據(jù)庫外,別無它出,采用A是很理智的。如果有,則需要取決于具體的情況使用<commit-option>方式。同時,<commit-option>方式的選擇與<locking-policy>策略有關(guān)系。 能夠采用<read-only>的Entity Beans或Entity Beans Methods,則盡量采用,這樣會減少或消除死鎖發(fā)生的可能性。 盡量采用1:n的關(guān)系來操作n方的數(shù)據(jù)表結(jié)構(gòu),這樣能夠提高EJB Container的效率。 其中,本文重點給出EJB事務(wù)處理方面的探討。 一般情況下,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) { (修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JDBC事務(wù)) 下面給出了JTA事務(wù)代碼示例: public void processOrder(String orderMessage) { (修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JTA事務(wù)) 同時,如果Session Bean采用JTA管理事務(wù),一定不要通過JNDI獲取JTA事務(wù),否則結(jié)果不堪設(shè)想;而是采用類似,“mySessionContext.getUserTransaction()”的方法獲取。 最后,可以使用容器管理事務(wù)(CMT)。在使用CMT過程中,如果聲明讓容器完成事務(wù)回滾,則目標(biāo)EJB應(yīng)用必須拋出系統(tǒng)級異常,否則容器是不會滿足事務(wù)的ACID。在包javax.ejb的異常類中,除了NoSuchEntityException和EJBException屬于系統(tǒng)級異常外,其他的異常全部是應(yīng)用級異常。 上述3點內(nèi)容,值得讀者注意??赡苡行┳x者在使用EJB CMT過程中,總是會遇到自己已經(jīng)將事務(wù)聲明為“Required”,但就是不能夠保證事務(wù)的ACID。因此,希望讀者注意J2EE應(yīng)用中事務(wù)使用的不同方式。詳細(xì)情況,可以參考J2EE Tutorial一書中的事務(wù)處理章節(jié)。 另外, 1) 在開發(fā)Entity Beans過程中,能夠使用CMP的地方盡量不要采用BMP的方式。如果擬采用BMP的方式,還不如采用Session Bean + JDBC,其中可以通過JTA控制事務(wù)(如果性能問題不是很重要的話)。 三,開發(fā)Web應(yīng)用 一般情況下,開發(fā)Web應(yīng)用最好采用一些Thirty-Part軟件或者Framework。比如,Struts、Log4j、webMethods等等。其優(yōu)勢顯而易見。 就目前而言,Struts的應(yīng)用基本上成為了開發(fā)Web應(yīng)用的標(biāo)準(zhǔn)。即將推出來的JSF很好的實現(xiàn)了與Struts的補充和集成。同時,JSF也將給快速開發(fā)JSP Web前端應(yīng)用帶來革命。另外,Struts也恰恰促進了JSF的發(fā)展。 開發(fā)JBoss 3.2.1下的Web應(yīng)用的過程和其他應(yīng)用服務(wù)器下都差不多。同時,JBuilder 8、9都已經(jīng)支持Struts 1.1。如果讀者需要JBoss 3.2.1下,結(jié)合Struts、EJB、JSP、Servlet、JavaBean相關(guān)實例的文章,可以給我提些建議。 四,總結(jié) 通過這兩次的文章,將開發(fā)J2EE應(yīng)用相關(guān)的幾個基本問題做了初步的探討。開發(fā)J2EE應(yīng)用涉及到的問題是一個系統(tǒng)工程問題,也不是幾篇文章、幾本書能夠回答清楚的,很多內(nèi)容需要大家在實踐中摸索、學(xué)習(xí),去進步。 謝謝大家。歡迎大家給我來信,共同探討J2EE相關(guān)開發(fā)、應(yīng)用問題。 |
|
|