我最初使用xapool創建了spring,但事實證明這是一個死了的項目,似乎有很多問題。spring事務性池。我使用哪一個?
我切換到c3p0,但現在我知道@Transactional註釋實際上不會在與c3p0一起使用時創建事務。如果我下面會甚至通過異常將該行插入符是在方法內部拋出:
@Service
public class FooTst
{
@PersistenceContext(unitName="accessControlDb") private EntityManager em;
@Transactional
public void insertFoo() {
em.createNativeQuery("INSERT INTO Foo (id) VALUES (:id)")
.setParameter("id", System.currentTimeMillis() % Integer.MAX_VALUE)
.executeUpdate();
throw new RuntimeException("Foo");
}
}
這很奇怪,因爲如果我註釋掉@Transactional註釋它實際上將失敗,並抱怨有事務設置爲僅回滾:
java.lang.IllegalStateException: Cannot get Transaction for setRollbackOnly
at org.objectweb.jotm.Current.setRollbackOnly(Current.java:568)
at org.hibernate.ejb.AbstractEntityManagerImpl.markAsRollback(AbstractEntityManagerImpl.java:421)
at org.hibernate.ejb.AbstractEntityManagerImpl.throwPersistenceException(AbstractEntityManagerImpl.java:576)
at org.hibernate.ejb.QueryImpl.executeUpdate(QueryImpl.java:48)
at com.ipass.rbac.svc.FooTst.insertFoo(FooTst.java:21)
at com.ipass.rbac.svc.SingleTst.testHasPriv(SingleTst.java:78)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.springframework.test.context.junit4.SpringTestMethod.invoke(SpringTestMethod.java:160)
at org.springframework.test.context.junit4.SpringMethodRoadie.runTestMethod(SpringMethodRoadie.java:233)
at org.springframework.test.context.junit4.SpringMethodRoadie$RunBeforesThenTestThenAfters.run(SpringMethodRoadie.java:333)
at org.springframework.test.context.junit4.SpringMethodRoadie.runWithRepetitions(SpringMethodRoadie.java:217)
at org.springframework.test.context.junit4.SpringMethodRoadie.runTest(SpringMethodRoadie.java:197)
at org.springframework.test.context.junit4.SpringMethodRoadie.run(SpringMethodRoadie.java:143)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.invokeTestMethod(SpringJUnit4ClassRunner.java:160)
at org.junit.internal.runners.JUnit4ClassRunner.runMethods(JUnit4ClassRunner.java:51)
at org.junit.internal.runners.JUnit4ClassRunner$1.run(JUnit4ClassRunner.java:44)
at org.junit.internal.runners.ClassRoadie.runUnprotected(ClassRoadie.java:27)
at org.junit.internal.runners.ClassRoadie.runProtected(ClassRoadie.java:37)
at org.junit.internal.runners.JUnit4ClassRunner.run(JUnit4ClassRunner.java:42)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:97)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:45)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
因此,顯然它注意到@Transactional註釋。但是,它並沒有在方法開始時將autocommit設置爲off。
這是我如何在applicationContext.xml中設置事務性的東西。它是否正確?如果沒有,這應該是什麼?
<bean id="jotm" class="org.springframework.transaction.jta.JotmFactoryBean"/>
<bean id="txManager" class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="transactionManager" ref="jotm"/>
<property name="userTransaction" ref="jotm"/>
<property name="allowCustomIsolationLevels" value="true"/>
</bean>
<tx:annotation-driven transaction-manager="txManager" proxy-target-class="false"/>
一堆搜索後,我發現所謂Bitronix一個連接池,但他們的春天設置頁面介紹了有關JMS它甚至沒有任何意義的東西。 JMS與建立連接池有什麼關係?
所以我卡住了。我實際上應該做什麼?我不明白爲什麼連接池需要支持事務。所有連接都支持打開和關閉自動提交功能,所以我不知道問題出在哪裏。
我使用tomcat,所以它不提供任何東西。 – HappyEngineer
確實如此 - 您爲什麼不要求它使用Jakarta DBCP提供連接池? http://tomcat.apache.org/tomcat-6.0-doc/jndi-datasource-examples-howto.html – duffymo
無論如何,我需要將應用程序上下文設置爲獨立運行或在tomcat下運行。 對於我的生活,我無法弄清楚如何讓事情剛剛運行,以便在@Transactional方法中拋出的異常導致在同一方法中執行的插入回滾。這非常令人沮喪。我不需要2階段提交或類似的東西。只需一個簡單的交易即可。除此之外的任何事情都是獎金。 – HappyEngineer