Spring MVC и EhCache не работает - PullRequest
0 голосов
/ 08 июня 2018

Я пытаюсь интегрировать ehcache в Spring mvc и hibernate-приложение, но ниже не работает код.Я перешел по ссылке - , как использовать ehcache весной mvc с hibernate , но я все еще сталкиваюсь с проблемой.Эта проблема возникает, когда я запускаю сервер.Я использую пружину 5.0.5

springmvc.xml

<beans:bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
        <beans:property name="dataSource" ref="dataSource" />
        <beans:property name="packagesToScan">
            <beans:array>
                <beans:value>com.kalavakuri.springmvcandorm</beans:value>
            </beans:array>
        </beans:property>
        <beans:property name="hibernateProperties">
            <beans:props>
                <beans:prop key="hibernate.dialect">${hibernate.dialect}</beans:prop>
                <beans:prop key="hibernate.show_sql">${hibernate.show_sql}</beans:prop>
                <beans:prop key="hibernate.cache.use_second_level_cache">true</beans:prop>
                <beans:prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory</beans:prop>
                <beans:prop key="hibernate.cache.provider_configuration_file_resource_path">ehcache.xml</beans:prop>
                <beans:prop key="hibernate.cache.use_query_cache">true</beans:prop>
                <!-- <beans:prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</beans:prop> -->
            </beans:props>
        </beans:property>
    </beans:bean>

ehcache.xml

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd">

    <diskStore path="java.io.tmpdir" />
    <!--defaultCache eternal="false" maxElementsInMemory="1000" maxElementsOnDisk="10000" 
        overflowToDisk="true" diskPersistent="true" timeToLiveSeconds="300" statistics="true" 
        copyOnWrite="true" / -->

    <cache name="student" maxElementsInMemory="100000"
        eternal="true" overflowToDisk="false" memoryStoreEvictionPolicy="LFU"
        statistics="true" timeToLiveSeconds="3600" />

</ehcache>

I am getting below error:

Caused by: org.hibernate.cache.CacheException: On-the-fly creation of JCache Cache objects is not supported [org.hibernate.cache.spi.TimestampsRegion]
    at org.hibernate.cache.ehcache.internal.EhcacheRegionFactory.createCache(EhcacheRegionFactory.java:106)
    at org.hibernate.cache.ehcache.internal.EhcacheRegionFactory.getOrCreateCache(EhcacheRegionFactory.java:100)
    at org.hibernate.cache.ehcache.internal.EhcacheRegionFactory.createTimestampsRegionStorageAccess(EhcacheRegionFactory.java:86)
    at org.hibernate.cache.spi.support.RegionFactoryTemplate.buildTimestampsRegion(RegionFactoryTemplate.java:70)
    at org.hibernate.cache.internal.EnabledCaching.<init>(EnabledCaching.java:80)
    at org.hibernate.engine.spi.CacheInitiator.initiateService(CacheInitiator.java:33)
    at org.hibernate.engine.spi.CacheInitiator.initiateService(CacheInitiator.java:24)
    at org.hibernate.service.spi.SessionFactoryServiceInitiator.initiateService(SessionFactoryServiceInitiator.java:30)
    at org.hibernate.service.internal.SessionFactoryServiceRegistryImpl.initiateService(SessionFactoryServiceRegistryImpl.java:68)
    at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:263)
    ... 99 more

Ответы [ 2 ]

0 голосов
/ 02 июля 2018

У меня была такая же проблема.После добавления @EnableCaching в приложение весенней загрузки проблема @SpringBootApplication была решена.Пожалуйста, попробуй.

0 голосов
/ 08 июня 2018

Согласно документации hibernate необходимо создать 2 других области кэша

  1. org.hibernate.cache.spi.UpdateTimestampsCache: тиос должен быть настолько большим, насколько это возможно (в идеале никогдасрок действия истекает)
  2. org.hibernate.cache.internal.StandardQueryCache

Hibernate не может создать их на лету (прежде всего первый)

На самом делеиспользуя ehcahe 3 и hibernate 5, я использую эту конфигурацию:

@Configuration
@EnableCaching
public class CacheConfiguration extends CachingConfigurerSupport
{
    @Autowired
    private Environment env;
    @Bean("cacheManager")
    @Override
    public org.springframework.cache.CacheManager cacheManager()
    {

        return new JCacheCacheManager(createCacheManager());
    }
    private CacheManager createCacheManager()
    {
        long dimensioneCache = new Long(env.getProperty("arca.context.cache.size"));
        long ttlMillisecondi = new Long(env.getProperty("arca.context.cache.ttl"));
        org.ehcache.config.CacheConfiguration<Object, Object> cacheConfiguration = CacheConfigurationBuilder.
                                                                                                newCacheConfigurationBuilder(Object.class, Object.class, 
                                                                                                ResourcePoolsBuilder.heap(dimensioneCache)
                                                                                                ).withExpiry(Expirations.timeToLiveExpiration(new org.ehcache.expiry.Duration(ttlMillisecondi, TimeUnit.MILLISECONDS))).build();
        Map<String, org.ehcache.config.CacheConfiguration<?, ?>> caches = createCacheConfigurations(cacheConfiguration);
        //Creo la cache di hibernate org.hibernate.cache.spi.UpdateTimestampsCache. 
        //Dalla documentazione di hibernate https://docs.jboss.org/hibernate/orm/5.2/userguide/html_single/Hibernate_User_Guide.html#caching
        ResourcePoolsBuilder rpb = ResourcePoolsBuilder.heap(dimensioneCache*1000000);
        org.ehcache.config.CacheConfiguration<Object, Object> eternalCacheConfiguration = CacheConfigurationBuilder.newCacheConfigurationBuilder(Object.class, Object.class, rpb).withExpiry(Expirations.noExpiration()).build();
        caches.put("org.hibernate.cache.spi.UpdateTimestampsCache", eternalCacheConfiguration);
        EhcacheCachingProvider provider = getCachingProvider();
        DefaultConfiguration configuration = new DefaultConfiguration(caches, provider.getDefaultClassLoader());
        CacheManager result = provider.getCacheManager(provider.getDefaultURI(), configuration);
        return result;
    }

    private Map<String, org.ehcache.config.CacheConfiguration<?, ?>> createCacheConfigurations(org.ehcache.config.CacheConfiguration<Object, Object> cacheConfiguration)
    {
        Map<String, org.ehcache.config.CacheConfiguration<?, ?>> caches = new HashMap<>();
        // I'm searcing for all objects with @Entity annotation in order to create cache regions
        ClassPathScanningCandidateComponentProvider scanner = new ClassPathScanningCandidateComponentProvider(false);
        scanner.addIncludeFilter(new AnnotationTypeFilter(Entity.class));
        for (BeanDefinition bd : scanner.findCandidateComponents("it.test.models"))
        {
            String className = bd.getBeanClassName();
            caches.put(className, cacheConfiguration);
        }
        //org.hibernate.cache.internal.StandardQueryCache creation
        caches.put("org.hibernate.cache.internal.StandardQueryCache", cacheConfiguration);
        return caches;
    }

    private EhcacheCachingProvider getCachingProvider()
    {
        return (EhcacheCachingProvider) Caching.getCachingProvider();
    }
}

В моей конфигурации hibernate я использую эту кэш-память it.olegna.tests.hibernate.cache.config.JCacheRegionFactory ее код следующий:

public class JCacheRegionFactory extends org.hibernate.cache.jcache.JCacheRegionFactory
{
    private static final long serialVersionUID = 1021281213463444167L;

    @Override
    protected Cache<Object, Object> createCache(String regionName, Properties properties, CacheDataDescription metadata)
    {
        throw new IllegalArgumentException("Unknown hibernate cache: " + regionName);
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...