6

Spring 3、Hibernate、および JPA を使用するアプリケーションに取り組んでいます。次のように2つのクラスがあります。

@Component
class Manager {
    @Autowired
    Util util;
}

@Component
class Util {
    @Autowired
    Manager manager;

    @Scheduled(fixedDelay = 1 * 60 * 1000)
    @Transactional(propagation = Propagation.REQUIRED)
    public void scheduledMethod(){
        // Need to update the database in a transaction
    }
}

アプリケーション コンテキストの関連部分は次のとおりです。

    <context:component-scan base-package="packageName" />
    <tx:annotation-driven />
    <bean id="entityManagerFactory"
    class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
       <property name="persistenceUnitName" value="defaultPU" />
       <property name="dataSource" ref="dataSource" />
    </bean>
    <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
       <property name="entityManagerFactory" ref="entityManagerFactory" />
    </bean>
    <task:annotation-driven executor="executor" scheduler="scheduler"/>
    <task:executor id="executor"
       pool-size="10"
       queue-capacity="10000"
       rejection-policy="CALLER_RUNS"/>
    <task:scheduler id="scheduler" pool-size="10"/>

この構成では、次の例外が発生します

javax.persistence.TransactionRequiredException: no transaction is in progress
        at org.hibernate.ejb.AbstractEntityManagerImpl.flush(AbstractEntityManagerImpl.java:978)
        at sun.reflect.GeneratedMethodAccessor88.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.springframework.orm.jpa.ExtendedEntityManagerCreator$ExtendedEntityManagerInvocationHandler.invoke(ExtendedEntityManagerCreator.java:365)
        at com.sun.proxy.$Proxy43.flush(Unknown Source)
        at sun.reflect.GeneratedMethodAccessor88.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at org.springframework.orm.jpa.SharedEntityManagerCreator$SharedEntityManagerInvocationHandler.invoke(SharedEntityManagerCreator.java:240)
        at com.sun.proxy.$Proxy43.flush(Unknown Source)

Util クラスから Manager クラスのオートワイヤリングを削除すると、正常に動作します。また、デバッグ中に、アプリケーション コンテキスト ファイルに何らかのエラーがあっても、スケジュールされたメソッドが実行を開始することがわかりました。

いくつかのレガシーな理由から、循環依存を避けることはできません。循環依存の場合にこの例外が発生する理由を誰かが助けることができますか?

4

1 に答える 1