Activation d'un cache 2nd level JBoss avec Hibernate
Bonjour,
J'essaie de mettre en place un cache JBoss sur ma configuration Spring + Hibernate.
Voici ma configuration Spring :
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="datasource" />
<property name="packagesToScan">
<list><value>test.model.**.*</value></list>
</property>
<property name="hibernateProperties">
<map>
<entry>
<key><value>hibernate.dialect</value></key>
<ref bean="dialect"/>
</entry>
<entry>
<key><value>hibernate.hbm2ddl.auto</value></key>
<value>update</value>
</entry>
<entry>
<key><value>hibernate.connection.autocommit</value></key>
<value>false</value>
</entry>
<entry>
<key><value>hibernate.transaction.manager_lookup_class</value></key>
<value>org.hibernate.transaction.JBossTransactionManagerLookup</value>
</entry>
<entry>
<key><value>hibernate.transaction.factory_class</value></key>
<value>org.hibernate.transaction.JTATransactionFactory</value>
</entry>
<entry>
<key><value>hibernate.cache.use_second_level_cache</value></key>
<value>true</value>
</entry>
<entry>
<key><value>hibernate.cache.use_query_cache</value></key>
<value>true</value>
</entry>
<entry>
<key><value>hibernate.cache.region.factory_class</value></key>
<value>org.hibernate.cache.jbc.MultiplexedJBossCacheRegionFactory</value>
</entry>
</map>
</property>
</bean>
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<tx:annotation-driven transaction-manager="transactionManager" /> |
Lorsque le démarre mon application sous Tomcat j'obtiens l'erreur ci-dessous :
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
|
[...]
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in class path resource [persistenceContext.xml]: Invocation of init method failed; nested exception is org.hibernate.cache.CacheException: Unable to start region factory
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1455)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:294)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:225)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:291)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:193)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.findAutowireCandidates(DefaultListableBeanFactory.java:848)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:790)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:707)
at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:795)
at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:723)
... 69 more
Caused by: org.hibernate.cache.CacheException: Unable to start region factory
at org.hibernate.cache.jbc.builder.MultiplexingCacheInstanceManager.start(MultiplexingCacheInstanceManager.java:438)
at org.hibernate.cache.jbc.JBossCacheRegionFactory.start(JBossCacheRegionFactory.java:107)
at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:250)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1385)
at org.hibernate.cfg.AnnotationConfiguration.buildSessionFactory(AnnotationConfiguration.java:954)
at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newSessionFactory(LocalSessionFactoryBean.java:860)
at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:779)
at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:188)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1514)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1452)
... 80 more
Caused by: org.hibernate.HibernateException: Could not locate TransactionManager
at org.hibernate.transaction.JNDITransactionManagerLookup.getTransactionManager(JNDITransactionManagerLookup.java:60)
at org.hibernate.cache.jbc.builder.MultiplexingCacheInstanceManager.start(MultiplexingCacheInstanceManager.java:307)
... 89 more
Caused by: javax.naming.NameNotFoundException: Le Nom TransactionManager n'est pas lié à ce Contexte
at org.apache.naming.NamingContext.lookup(NamingContext.java:770)
at org.apache.naming.NamingContext.lookup(NamingContext.java:153)
at org.apache.naming.SelectorContext.lookup(SelectorContext.java:152)
at javax.naming.InitialContext.lookup(InitialContext.java:392)
at org.hibernate.transaction.JNDITransactionManagerLookup.getTransactionManager(JNDITransactionManagerLookup.java:57)
... 90 more |
Il semble que je cherche une ressource JNDI "TransactionManager" depuis un "JNDITransactionManagerLookup" alors que j'ai clairement défini un "JBossTransactionManagerLookup" pour la propriété "hibernate.transaction.manager_lookup_class". Est-ce normal ?
Merci.