从应用程序获取休眠会话计数

Posted

技术标签:

【中文标题】从应用程序获取休眠会话计数【英文标题】:Getting Hibernate Session Count from application 【发布时间】:2014-03-03 23:15:35 【问题描述】:

我创建了简单的 Java 应用程序来学习 Spring 和 hibernate 集成。我已经完成了所有设置和应用程序也可以正常工作。

一切正常。但是,我想看看我的应用程序当前使用了多少会话,例如打开连接和关闭的休眠连接。

Sessionfactory 类中,我们有 "getStatistics" 方法用于检索休眠统计数据,但这对我没有帮助。它也给了我零。请在下面找到图片。

我想确保我的应用程序是否对整个应用程序操作使用单个会话。

那么有什么方法可以找出或获取 Spring+hibernate 会话数。

我的休眠配置文件;

<?xml version="1.0" encoding="UTF-8"?>

http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">

<bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource"
    destroy-method="close">
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:XE" />
    <property name="username" value="rocky" />
    <property name="password" value="rocky" />
</bean>

<bean id="mySessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource" ref="myDataSource" />
    <property name="mappingResources">
        <list>
            <value>orders.hbm.xml</value>
        </list>
    </property>
    <property name="hibernateProperties">
        <map>
            <entry>
                <key>
                    <value>hibernate.show_sql</value>
                </key>
                <value>true</value>
            </entry>
            <entry>
                <key>
                    <value>hibernate.dialect</value>
                </key>
                <value>org.hibernate.dialect.OracleDialect</value>
            </entry>
            <entry>
                <key>
                    <value>hibernate.query.factory_class</value>
                </key>
                <value>org.hibernate.hql.classic.ClassicQueryTranslatorFactory</value>
            </entry>
            <entry>
                <key>
                    <value>connection.autocommit</value>
                </key>
                <value>true</value>
            </entry>
        </map>
    </property>
</bean>

<bean id="transactionManager"
    class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="mySessionFactory" />
</bean>

<bean id="txManager"
    class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="mySessionFactory" />
</bean>

<bean id="transactionProxy"
    class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
    <property name="transactionManager" ref="txManager" />
    <property name="transactionAttributes">
        <props>
            <prop key="*">PROPAGATION_REQUIRED</prop>
        </props>
    </property>
    <property name="target" ref="myServiceClass">
    </property>
</bean>

<tx:annotation-driven transaction-manager="txManager" />

<bean id="myServiceClass" class="myServiceClass">
    <property name="sessionFactory" ref="mySessionFactory" />
</bean>

【问题讨论】:

【参考方案1】:

查看您的代码,您似乎没有启用会话工厂的静态功能

无法使用会话工厂静态数据的步骤

SessionFactory sessionFactory = getSessionFactoryForApplication();
Statistics stats = sessionFactory.getStatistics();
stats.setStatisticsEnabled(true);

取自article

希望这能解决您的问题..!

【讨论】:

统计对象的每个方法都返回零,没有用。

以上是关于从应用程序获取休眠会话计数的主要内容,如果未能解决你的问题,请参考以下文章

从会话工厂以编程方式获取休眠默认模式名称?

使用计数和连接从休眠的实体中获取行

休眠“在视图中打开会话”和异步任务

无法为事务打开休眠会话/无法打开连接 [关闭]

从 IIS 获取我托管的 Asp.Net 网站的运行会话计数

在 AsyncUncaughtExceptionHandler 中获取休眠会话