Hibernate Caching не улучшает производительность

Мое приложение-context.xml:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
..
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    ..
default-autowire="byName">

<import resource="jms-context.xml" />

<context:property-placeholder location="classpath:res.properties" />

<context:annotation-config />
<context:component-scan base-package="..." />


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

<bean id="PROPAGATION_REQUIRED"
    class="org.springframework.transaction.support.TransactionTemplate">
    <property name="transactionManager" ref="transactionManager" />
    <property name="propagationBehaviorName" value="PROPAGATION_REQUIRED" />
</bean>


<bean id="pooledDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
    destroy-method="close">
    <property name="driverClass" value="${jdbc.database.driverClass}" />
    <property name="jdbcUrl" value="${jdbc.database.url}" />
    <property name="user" value="${jdbc.database.username}" />
    <property name="password" value="${jdbc.database.password}" />
     ...
</bean>

<bean id="GLOBAL" class="oracle.jdbc.pool.OracleDataSource"
    destroy-method="close" p:URL="${jdbc.database.url}" p:user="${jdbc.database.username}"
    p:password="${jdbc.database.password}">
    <property name="connectionCachingEnabled" value="true" />
    <property name="connectionCacheProperties">
        <util:map>
            <entry key="MinLimit" value="${jdbc.database.minLimit}" />
            <entry key="MaxLimit" value="${jdbc.database.maxLimit}" />
            <entry key="InitialLimit" value="${jdbc.database.initialLimit}" />
        </util:map>
    </property>
</bean>

<bean id="global-tm" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="global-em" />
    <property name="dataSource" ref="GLOBAL" />
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="global-em" />
</bean>

<bean id="jpaVendorAdapter"  class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
    <property name="showSql" value="false" />
    <property name="generateDdl" value="false" />
    <property name="databasePlatform" value="${jpa.hibernate.dialectClass}" />
</bean>

<bean id="global-em"
    class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
    p:packagesToScan="..." p:dataSource-ref="pooledDataSource"
    p:jpaVendorAdapter-ref="jpaVendorAdapter">
    <property name="jpaPropertyMap">
        <map>
            <entry key="hibernate.temp.use_jdbc_metadata_defaults" value="false" />
            <entry key="hibernate.cache.region.factory_class"
                value="org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory" />
            <entry key="hibernate.cache.use_second_level_cache" value="true" />
            <entry key="hibernate.cache.use_query_cache" value="true" />
            <entry key="javax.persistence.sharedCache.mode" value="ENABLE_SELECTIVE" />
            <entry key="hibernate.generate_statistics" value="true" />
        </map>
    </property>
</bean>

<bean   class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" />


 </beans>

Я аннотировал свои сущности следующим образом:

import javax.persistence.Cacheable;
import org.hibernate.annotations.Cache;

@Cacheable
@Cache(usage = org.hibernate.annotations.CacheConcurrencyStrategy.READ_ONLY)

DSL в Camel Route Builder выглядит следующим образом:

from(fromURI)
     ...
    .policy(required)
    .bean(bean1, "proc") 
        ...
        .recipientList().method(recipientList, "endPoint")
    ...
    .end();

Но я не мог заметить каких-либо ощутимых улучшений. Я что-то пропустил?

Мои ограничения:

  1. Я не могу использовать Hibernate как (org.hibernate.annotations.Cache) непосредственно в моем коде, так как мой код должен соответствовать JPA.
  2. Мои объекты аннотированы. Таким образом, бины не могут быть настроены Cacheable через hbm.xml

1 ответ

Использовать этот спящий завод

net.sf.ehcache.hibernate.EhCacheRegionFactory

вместо

org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory

Я использую ehcache в течение некоторого времени в моем проекте, и, конечно же, его сокращение не происходит. запросов уволено.

Пожалуйста, дайте мне знать, если у вас есть какие-либо проблемы.

Другие вопросы по тегам