浏览 23488 次
该帖已经被评为精华帖
|
|
---|---|
作者 | 正文 |
发表时间:2003-09-16
我机器上的有个Hibernate的项目,在D:\test\oracle目录下,该目录下的结构是: D:\test\oracle\lib 放置hibernate的所有jar包 D:\test\oracle\src 放置源代码 D:\test\oracle\classes 编译好的代码和hibernate的配置文件(hibernate.properties, log4j.properties, cache.ccf); 现在需要把D:\test\oracle\lib目录下那些jar文件和D:\test\oracle\classes目录都放置到Weblogic的 CLASSPATH里面去,所以修改mydomain里面的Weblogic启动脚本startWeblogic.cmd,在启动Weblogic之前,插入设置CLASSPATH的命令,如下: @rem set hibernate classpath set HIBERNATE_LIB=D:\test\oracle\lib set HIBERNATE_CLASSES=D:\test\oracle\classes set 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_CLASSES%;%CLASSPATH% 下面一行,就是本来脚本里面的启动命令: @rem Call Weblogic Server call "C:\bea\weblogic700\server\bin\startWLS.cmd" 二、在Weblogic上配置 Oracle数据库的连接池。这一步本来和Hibernate无关,但是如果你想要使用EJB,想要使用JTA,那么必须使用Weblogic提供的连接池,而不能使用Hibernate自带的连接池,或者其它第三方连接池,否则容器将无法管理数据库事务。这一步很简单,就是在Weblogic Console里面配置Connection Pool和TxData Source,我的Tx DataSource取名称为“mypool” 三、修改hibernate.properties。使用Weblogic的连接池,而不是自带的连接池。我修改的是D:\test\oracle\classes\hibernate.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 分别对数据库查询和插入有很大的性能影响,调节这两个选项可以得到最好的性能。 为了保证SessionFactory实例的预创建,使用Weblogic的T3StartUpDef接口创建一个StartUp类,在Weblogic启动的时候运行: package com.fankai; import java.util.Hashtable; import weblogic.common.T3StartupDef; import weblogic.common.T3ServicesDef; import net.sf.hibernate.cfg.Configuration; import net.sf.hibernate.SessionFactory; public class HibernateStartUp implements T3StartupDef { public void setServices(T3ServicesDef services); {} public String startup(String name, Hashtable args); throws Exception { Configuration conf = new Configuration();.addClass(Cat.class);; SessionFactory sf = conf.buildSessionFactory();; return "Hibernate Startup completed successfully"; } } 代码非常简单,其实就是确保预先运行 Configuration conf = new Configuration();.addClass(Cat.class);; SessionFactory sf = conf.buildSessionFactory();; 把sf创建出来,而Hibernate会自行调用一系列类方法,把sf绑定到Weblogic的的JNDI树下的hibernate/session_factory路径中。 4、编译HibernateStartUp.java 编译这个源代码的时候需要注意的是,要把weblogic.jar包和Hibernate所有的相关包和配置文件导入。我是把这个源代码放到D:\test\oracle\src目录下的,用早已编写好的ant脚本运行一下就编译好了,并且编译好的 class文件被放置到D:\test\oracle\classes目录下,该目录已经被加入到Weblogic的CLASSPATH里面,因此很省事。 五、配置StartUp类 启动Weblogic,打开Console控制台,在左边的Applet树上找到StartUp & Shutdown,然后在右边点击“Configure a new Startup Class...”,在Name框里面随便填写,在ClassName里面填写你编写的StartUp类,我填写的是 com.fankai.HibernateStartUp ,然后点击“Apply”。然后切换到Target这选项卡,在Target-Server左边的 Avaiable框里面选择“myserver”,点击右箭头,把它挪到右边的“Chosen”框里面去,最后再点击一下“Apply"按钮。如果此时 Weblogic的DOS窗口里面没有出错信息,那么应该已经配置成功了。 六、现在关闭Weblogic,再重新运行 startWelogic.cmd,启动Weblogic,观察DOS窗口的输出信息,可以看到Hibernate的初始化信息一屏屏的滚动输出,证明已经配置成功。现在再打开Console控制台,点击左边Applet树中的Servers|myserver,然后可以在右边最下面找到“View JNDI tree ”,点击它,会打开一个浏览器窗口,显示JNDI树,这时你可以看到一个名称为hibernate的JNDI对象,在左边的Applet树中点击它,看右边的详细信息,我的机器上的信息如下: Bind Name: hibernate Object Class: net.sf.hibernate.impl.SessionFactoryImpl Object Hash Code: 454492 Object To String: net.sf.hibernate.impl.SessionFactoryImpl@6ef5c 完全正确! 最后你可以随意在EJB或者Servlet/JSP里面使用JND查找来获得SessionFactory了。 例如: Context ctx = new InitialContext();; SessionFactory sf = (SessionFactory); ctx.lookup("hibernate/session_factory");; 在其它App Server上如何配置,本质上和Weblogic是一样的,只是你要确保在其它程序运行之前,先把 Configuration conf = new Configuration();.addClass(Cat.class);; SessionFactory sf = conf.buildSessionFactory();; 这两行代码运行一遍就OK了 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2005-03-09
如果要用到兩個或兩個以上的數據庫,就是說一個sessionFactary不夠,應該證明配置?
按照你上面的是,jndi一定就是hibernate/session_factory, 問題的焦點在於啟動類中創建的sf怎麼和那個jndi name綁定的。 難道說weblogic只支持一個數據庫的hibernate綁定嗎? 希望不吝賜教﹗ thank you! |
|
返回顶楼 | |
发表时间:2005-03-09
你不会为每个SessionFactory建立一个独立的hibernate.properties文件吗
|
|
返回顶楼 | |
发表时间:2005-08-08
如果是用hibernate3.0时,把Hibernate 用到的jar包和配置文件都放到Weblogic能够搜索到的CLASSPATH路径上时,要具体把是那些.jar????
|
|
返回顶楼 | |
发表时间:2006-02-23
robbin 写道 你不会为每个SessionFactory建立一个独立的hibernate.properties文件吗
我现在也有这种部问题,我的weblogic中有多个数据源,我想让hibernate也支持多个数据源,我应如何写多个 hibernate.properties以及hibernate.cfg.xml 我难不成要换名 改为 eaiDatahibernate.properties以及eaiDatahibernate.cfg.xml 还请你给指名一下,具体的思路,谢谢 |
|
返回顶楼 | |
发表时间:2006-02-23
是不是建立多个cfg.xml 并在 xml写原hibernate.properties的配置功能,然后加指定加载
如下 sessionFactory = new Configuration();.configure("oracle.cfg.xml");.buildSessionFactory();; |
|
返回顶楼 | |
发表时间:2006-02-23
我在网上又找到了一些资料,可以这样来完成
Configuration levyConfig = new Configuration();.configure(new File("${dir}/hibernate-levy.hbm.xml"););; Configuration mgtConfig = new Configuration();.configure(new File("${dir}/hibernate-mgt.hbm.xml"););; 但是new 好 Configuration 给 sessionFactory,但是sessionFactory只有一个,在进行openSession时,做一个save操作,HIBERNATE他是如何知道,应给存入哪个数据库,是不是应有多个sessionFactory才可以 如果我想用一个 sessionFactory 如何来换链接呢 |
|
返回顶楼 | |
发表时间:2006-02-23
我又想到一个办法得到多个 sessionFactory,然后编号 放到一个 static 的map中,如果我链接哪个数据库,我就在map get出来,不知道这样行不行
|
|
返回顶楼 | |
发表时间:2006-04-13
lianga 写道 我在网上又找到了一些资料,可以这样来完成
Configuration levyConfig = new Configuration();.configure(new File("${dir}/hibernate-levy.hbm.xml"););; Configuration mgtConfig = new Configuration();.configure(new File("${dir}/hibernate-mgt.hbm.xml"););; 但是new 好 Configuration 给 sessionFactory,但是sessionFactory只有一个,在进行openSession时,做一个save操作,HIBERNATE他是如何知道,应给存入哪个数据库,是不是应有多个sessionFactory才可以 如果我想用一个 sessionFactory 如何来换链接呢 |
|
返回顶楼 | |
发表时间:2006-04-13
我尝试hibernate3用weblogic JNDI这样是可以的,与大家分享!请大家指正!但是用多个数据源的问题还是没有解决!
<property name="hibernate.connection.datasource">jdbc/abc</property> <property name="hibernate.transaction.factory_class">org.hibernate.transaction.JTATransactionFactory</property> <property name="hibernate.transaction.manager_lookup_class">org.hibernate.transaction.WeblogicTransactionManagerLookup</property> <property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property> |
|
返回顶楼 | |