Bonjour,
J'essaie de mettre en place un cache JBoss sur ma configuration Spring + Hibernate.
Voici ma configuration Spring :
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
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" />
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 ?
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
Merci.
Partager