一、首先需要把Hibernate 用到的jar包和配置文件都放到Weblogic能夠搜索到的CLASSPATH路徑上。單單這一步就有很多人很迷茫,其實去仔細看看Weblogic的啟動腳本文件startWeblogic.cmd和startWLS.cmd,我想大部分人都知道該怎么配置了。
我機器上的有個Hibernate的項目,在D: estOracle目錄下,該目錄下的結構是:
D: estoraclelib 放置hibernate的所有jar包
D: estoraclesrc 放置源代碼
D: estoracleclasses 編譯好的代碼和hibernate的配置文件(hibernate.PRoperties, log4j.properties, cache.ccf)
現在需要把D: estoraclelib目錄下那些jar文件和D: estoracleclasses目錄都放置到Weblogic的 CLASSPATH里面去,所以修改mydomain里面的Weblogic啟動腳本startWeblogic.cmd,在啟動Weblogic之前,插入設置CLASSPATH的命令,如下:
@rem set hibernate classpath
set HIBERNATE_LIB=D: estoraclelib
set HIBERNATE_CLASSES=D: estoracleclasses
set CLASSPATH=%CLASSPATH%;%HIBERNATE_LIB%cglib-asm.jar;%HIBERNATE_LIB%commons-beanutils.jar;
%HIBERNATE_LIB%commons-collections.jar;%HIBERNATE_LIB%commons-lang.jar;
%HIBERNATE_LIB%commons-logging.jar;%HIBERNATE_LIB%dom4j-full.jar;
%HIBERNATE_LIB%hibernate2.jar;%HIBERNATE_LIB%jcs.jar;
%HIBERNATE_LIB%log4j-1.2.8.jar;%HIBERNATE_LIB%odmg.jar;
%HIBERNATE_LIB%jta.jar;%HIBERNATE_CLASSES%;
下面一行,就是本來腳本里面的啟動命令:
@rem Call Weblogic Server
call "C:·eaweblogic700server·instartWLS.cmd"
二、在Weblogic上配置 Oracle數據庫的連接池,這一步本來和Hibernate無關,但是假如你想要使用EJB,想要使用JTA,那么必須使用Weblogic提供的連接池,而不能使用Hibernate自帶的連接池,或者其它第三方連接池,否則容器將無法治理數據庫事務。這一步很簡單,就是在Weblogic Console里面配置Connection Pool和TxData Source,我的TxDataSource取名稱為“mypool”
三、修改hibernate.properties。使用Weblogic的連接池,而不是自帶的連接池。我修改的是D: estoracleclasseshibernate.properties,增加如下行:
hibernate.dialect net.sf.hibernate.dialect.OracleDialect
hibernate.connection.datasource mypool
hibernate.connection.provider_class net.sf.hibernate.connection.DatasourceConnectionProvider
hibernate.session_factory_name hibernate.session_factory
注重最后一行,這是使用 Hibernate來綁定JNDI給JNDI起的名稱,本來應該是hibernate/session_factory,但是Weblogic要求改為. 號,不過在程序中lookup的時候還是要寫hibernate/session_factory
另外提到一點的是
hibernate.jdbc.fetch_size 50
hibernate.jdbc.batch_size 25
分別對數據庫查詢和插入有很大的性能影響,調節這兩個選項可以得到最好的性能。
新聞熱點
疑難解答