Org.hibernate.HibernateException: no TransactionManagerLookup parameter specified when updating hibernation

I am running spring 4.1.4, hibernate 4.3.8, atomikos 3.9.3, java 8, tomcat 8.

I see the above exception in localhost.log when starting my server, but I'm not sure where to configure TransactionManagerLookup separately from where I already configure it. This did not happen before updating hibernation, so this is most likely a version issue. Can anyone help?

FYI: catalina.out does not show anything useful. Just:

SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.startInternal Error listenerStart SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.startInternal Context [] startup failed due to previous errors 

My appContext defines:

 <prop key="hibernate.transaction.factory_class">org.hibernate.engine.transaction.internal.jta.CMTTransactionFactory</prop> <prop key="hibernate.transaction.manager_lookup_class">com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup</prop> 

and full stack trace:

 22-Jan-2015 10:07:25.734 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class com.my.app.web.InitializerListener org.hibernate.HibernateException: No TransactionManagerLookup specified at org.hibernate.context.internal.JTASessionContext.currentSession(JTASessionContext.java:85) at org.hibernate.internal.SessionFactoryImpl.getCurrentSession(SessionFactoryImpl.java:1014) at com.my.app.dao.AbstractMyDAO.currentSession(AbstractMyDAO.java:116) at com.my.app.dao.AbstractMyDAO.criteria(AbstractMyDAO.java:86) at com.my.app.dao.AbstractMyDAO.count(AbstractMyDAO.java:79) at com.my.app.initialize.MyInitializerImpl.initializeApplicaiton(MyInitializerImpl.java:69) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:483) at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:317) at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:190) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) at org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation(TransactionInterceptor.java:99) at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:281) at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207) at com.sun.proxy.$Proxy220.initializeApplicaiton(Unknown Source) at com.my.app.web.MyInitializerListener.contextInitialized(MyInitializerListener.java:42) at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4772) at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5196) at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150) at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:725) at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:701) at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:714) at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:917) at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1701) at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) at java.util.concurrent.FutureTask.run(FutureTask.java:266) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at java.lang.Thread.run(Thread.java:745) 

EDIT: Atomicos Transaction Manager configured as such

 <bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close"> <property name="forceShutdown" value="true" /> <!-- in secs --> <property name="transactionTimeout" value="300"/> </bean> <bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp"> <!-- in secs --> <property name="transactionTimeout" value="300" /> </bean> <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"> <property name="transactionManager" ref="atomikosTransactionManager" /> <property name="userTransaction" ref="atomikosUserTransaction" /> <property name="transactionSynchronizationName" value="SYNCHRONIZATION_ON_ACTUAL_TRANSACTION" /> <property name="allowCustomIsolationLevels" value="true"/> </bean> 

EDIT 2:

I think I need to clarify the situation a bit. I have a DAO object called AbstractMyDAO (as you can see from the stack). This object defines a factory session.

 @Autowired private SessionFactory mySessionFactory; 

when calling currentSession, the above error is raised because hibernate cannot find the transaction manager search associated with this factory session.

 public Session currentSession() { return mySessionFactory.getCurrentSession(); } 

This factory session is defined in the application context file as such:

 <bean id="mySessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> <property name="dataSource"> <ref bean="myDataSource" /> </property> <property name="annotatedClasses"> <list> <value>some values... </value> ... </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect"> ${gst.hibernate.dialect} </prop> <prop key="query.factory_class"> org.hibernate.hql.ast.ASTQueryTranslatorFactory </prop> <prop key="hibernate.max_fetch_depth">3</prop> <prop key="hibernate.show_sql">${my.hibernate.showsql}</prop> <prop key="hibernate.cache.use_query_cache">true</prop> <prop key="hibernate.cache.use_second_level_cache">true</prop> <prop key="hibernate.cache.use_structured_entries">true</prop> <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.SingletonEhCacheRegionFactory</prop> <prop key="net.sf.ehcache.configurationResourceName">${ehcache.my.persist.config}</prop> <prop key="hibernate.connection.isolation">3</prop> <prop key="connection.release_mode">auto</prop> <prop key="hibernate.current_session_context_class">jta</prop> <prop key="hibernate.transaction.factory_class">org.hibernate.engine.transaction.internal.jta.CMTTransactionFactory</prop> <prop key="hibernate.transaction.manager_lookup_class">com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup</prop> <prop key="hibernate.search.default.directory_provider">filesystem</prop> <prop key="hibernate.search.default.indexBase">/var/log/my/lucene/indexes</prop> </props> </property> </bean> 

As you can see, the hibernate.transaction.manager_lookup_class property is defined, but cannot be found when the bean is created, and I have no idea why. Is the configuration changed?

EDIT 3: When I debug: final JtaPlatform jtaPlatform = factory (). getServiceRegistry (). getService (JtaPlatform.class);

It returns the NoJTAP platform. I think this is my problem.

EDIT 4: It seems that there is nothing that implements JtaPlatform suitable for tomcat, or am I going to die?

+6
source share
2 answers

The answer to my question is here .

"In Hibernate 4.3, the long obsolete TransactionManagerLookup has been removed. Now the JTA provider must implement org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform."

+1
source

Make sure you also set up Atomicos transaction manager, so TransactionManagerLookup can find UserTransaction accordingly:

 <bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close"> <property name="transactionTimeout" value="300" /> </bean> <bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp"> <property name="transactionTimeout" value="300" /> </bean> <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"> <property name="transactionManager" ref="atomikosTransactionManager" /> <property name="userTransaction" ref="atomikosUserTransaction" /> </bean> 

Then you should also use the Spring EntityManager factory:

 <bean id="entityManager" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean" p:dataSource-ref="dataSource" p:persistenceXmlLocation="**/persistence.xml" p:persistenceUnitName="persistenceUnit" depends-on="dataSource, transactionManager"> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> </bean> </property> <property name="jpaProperties"> <props> <prop key="hibernate.transaction.factory_class">org.hibernate.engine.transaction.internal.jta.CMTTransactionFactory</prop> <prop key="hibernate.transaction.manager_lookup_class">com.atomikos.icatch.jta.hibernate3.TransactionManagerLookup</prop> ... </props> </property> </bean> 

Then the DAO should enter the EntityManager:

 @PersistenceContext(unitName = "persistenceUnit") private EntityManager entityManager; 

Instead of directly calling currentSession (AbstractMyDAO):

 at com.my.app.dao.AbstractMyDAO.currentSession(AbstractMyDAO.java:116) 
+1
source

Source: https://habr.com/ru/post/981395/


All Articles