posts - 51, comments - 17, trackbacks - 0, articles - 9
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          JBoss

          Posted on 2007-03-01 10:47 chenweicai 閱讀(173) 評論(0)  編輯  收藏
          JBoss,作為J2EE應用服務器,以其EJB容器卓越的性能、技術的潮流性、開發部署J2EE應用的方便性贏得了很多J2EE開發者的信賴。其中,免安裝、基于JMX構架、熱部署(Hot?Deploy)、快速開發EJB應用等幾項特征與其他商用服務器相比,顯得有些得意忘形的樣子。盡管其本身沒有重大的缺陷,但畢竟是Open?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</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應用只需要本地事務,則上述過程已經完成了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>
          ??????<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>
          。。。。。。。。
          其中,<datasource>java:/VSSDB</datasource>中的VSSDB就是mssql-ds.xml配置的數據源;而“java:/”前綴表明該命名空間只是對JBoss本身可見,即運行于JBoss外的應用是不能夠使用這里定義的數據源,這一點希望讀者注意。
          其次,<datasource-mapping>MS?SQLSERVER2000</datasource-mapping>中的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文件。比如,其中一段配置示例如下:
          ??????<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>
          比如,為了調節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,則將其中的<call-logging>屬性的取值改為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>方式。同時,<commit-option>方式的選擇與<locking-policy>策略有關系。
          能夠采用<read-only>的Entity?Beans或Entity?Beans?Methods,則盡量采用,這樣會減少或消除死鎖發生的可能性。
          盡量采用1:n的關系來操作n方的數據表結構,這樣能夠提高EJB?Container的效率。

          待續。。。。。。

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 德格县| 怀远县| 勐海县| 汾西县| 永新县| 花莲市| 景德镇市| 隆德县| 大田县| 昌吉市| 始兴县| 桑日县| 鄂尔多斯市| 宣威市| 张掖市| 东丽区| 任丘市| 札达县| 新津县| 利津县| 海兴县| 灵石县| 长寿区| 云阳县| 平舆县| 七台河市| 文安县| 浏阳市| 民和| 大邑县| 右玉县| 民权县| 阿克陶县| 乃东县| 阜新市| 高安市| 湛江市| 八宿县| 乌苏市| 遂川县| 镶黄旗|