2015-01-22 1 views
6

Я бег весны 4.1.4, 4.3.8 зимуют, atomikos 3.9.3, Java 8, 8.org.hibernate.HibernateException: Нет TransactionManagerLookup указано на спящем режиме не обновит

кот

я вижу выше исключение в локальном хосте .log при запуске моего сервера, но я не уверен, где настроить TransactionManagerLookup отдельно от того, где я уже его настраиваю. Этого не произошло, прежде чем обновлять спящий режим, так что это, скорее всего, проблема с версией. Может ли кто-нибудь помочь?

FYI: catalina.out не показывает ничего полезного. Просто:

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 

Мой контекст приложения определяет:

<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> 

и полный стек трассировки:

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: Менеджер Atomikos транзакции сконфигурирован как таковой

<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:

Думаю, мне нужно немного прояснить ситуацию. У меня есть объект DAO, называемый AbstractMyDAO (как вы можете видеть из стека). В этом объекте определяются сессионного завод

@Autowired 
private SessionFactory mySessionFactory; 

когда currentSession называется выше ошибка возникает потому, что спящий режим не может найти поиск менеджера транзакций, связанный с этой сессией заводом.

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

Эта сессия завода определяется в моем приложении контекста файла, как например:

<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> 

Как вы можете видеть, свойство hibernate.transaction.manager_lookup_class сейчас определяется, но не может быть найден, когда bean создан, и я понятия не имею, почему. Изменена ли конфигурация?

РЕДАКТИРОВАТЬ 3: Когда я отладка: окончательного JtaPlatform jtaPlatform = (завод) getServiceRegistry() GetService (JtaPlatform.class);..

Он возвращает платформу NoJTAP. Думаю, это моя проблема.

EDIT 4: Кажется, что ничего не реализует JtaPlatform, которая подходит для tomcat, или я умрую?

ответ

1

Ответ на мой вопрос here.

«В Hibernate 4.3 устаревший TransactionManagerLookup удален. Теперь поставщик JTA должен реализовать org.hibernate.engine.transaction.jta.platform.spi.JtaPlatform."

1

Убедитесь, что вы также настроить Transaction Manager Atomikos тоже, так что TransactionManagerLookup может найти UserTransaction соответственно:

<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> 

Затем вы должны использовать Spring EntityManager завод тоже:

<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> 

Тогда DAO следует вводить EntityManager:

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

Вместо вызова currentSession (AbstractMyDAO) непосредственно:

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

Спасибо, у меня уже был настроен диспетчер транзакций atomikos (см. Редактирование), но не диспетчер сущностей. Я дам ему попытку и отправлю отчет :) –

+0

Не могли бы вы объяснить мне, почему мне нужно будет использовать диспетчер сущностей? Моя заявка работала ранее без этого компонента. Проблема произошла только после спящего режима. Благодарю. –

+0

Это потому, что Hibernate перешел к реализации JPA, вместо того, чтобы использоваться как автономная структура ORM. Вы все еще можете использовать SessionFactory, но лучше использовать Spring 'LocalSessionFactoryBean', потому что вы также получаете автоматическое управление сеансом и JDBC. –

Смежные вопросы