Bonjour,

J'essaie de mettre en place un cache JBoss sur ma configuration Spring + Hibernate.

Voici ma configuration Spring :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
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 : Sélectionner tout - Visualiser dans une fenêtre à part
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.