2017-05-08 142 views
0

我想遷移到事務API 1.2,而不是1.1 JTA當騾子/春天的ClassLoader問題。遷移到事務API 1.2

雖然我知道我可以調整騾子提供林達我無法理解爲什麼應用程序不能僅僅通過增加交易-API應用程序/ lib文件夾中工作。沒有交易api一切都按預期工作,但我得到:

Caused by: java.lang.ClassNotFoundException: javax.transaction.Transactional 
at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[?:1.8.0_66] 
at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[?:1.8.0_66] 
at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[?:1.8.0_66] 
at org.springframework.transaction.annotation.JtaTransactionAnnotationParser.parseTransactionAnnotation(JtaTransactionAnnotationParser.java:42) ~[spring-tx-4.2.4.RELEASE.jar:4.2.4.RELEASE] 
at org.springframework.data.repository.core.support.TransactionalRepositoryProxyPostProcessor$CustomAnnotationTransactionAttributeSource.determineTransactionAttribute(TransactionalRepositoryProxyPostProcessor.java:229) ~[?:?] 
at org.springframework.data.repository.core.support.TransactionalRepositoryProxyPostProcessor$CustomAnnotationTransactionAttributeSource.findTransactionAttribute(TransactionalRepositoryProxyPostProcessor.java:208) ~[?:?] 
at org.springframework.data.repository.core.support.TransactionalRepositoryProxyPostProcessor$AbstractFallbackTransactionAttributeSource.computeTransactionAttribute(TransactionalRepositoryProxyPostProcessor.java:397) ~[?:?] 
at org.springframework.data.repository.core.support.TransactionalRepositoryProxyPostProcessor$AbstractFallbackTransactionAttributeSource.getTransactionAttribute(TransactionalRepositoryProxyPostProcessor.java:345) ~[?:?] 
at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:270) ~[spring-tx-4.2.4.RELEASE.jar:4.2.4.RELEASE] 

這是一些相關的Spring代碼片斷。

spring-data-commons(應用程序/ lib目錄):

  if (jta12Present) { 
      this.annotationParsers.add(new JtaTransactionAnnotationParser()); 
     } 

其中:

 private static final boolean jta12Present = ClassUtils.isPresent("javax.transaction.Transactional", 
      CustomAnnotationTransactionAttributeSource.class.getClassLoader()); 

- 好像當事務API被添加到應用程序傳遞此檢查。

JtaTransactionAnnotationParser從騾提供的彈簧-TX(MULE_HOME \ lib中\ OPT)到來。這是它拋出一個異常:

public class JtaTransactionAnnotationParser implements TransactionAnnotationParser, Serializable { 
    @Override 
    public TransactionAttribute parseTransactionAnnotation(AnnotatedElement ae) { 
     AnnotationAttributes attributes = AnnotatedElementUtils.getMergedAnnotationAttributes(ae, javax.transaction.Transactional.class); - ClassNotFoundException 

爲什麼春天識別在一個地方事務,但不能在其他?似乎有不同的範圍彈簧數據共用和彈簧TX可能是原因,但我不明白爲什麼,因爲騾子是應該提供一個複雜的層次的ClassLoader結構和跨越整個層次的搜索。

回答

0

好了,說完想過多一點,我想我最好現在明白了。正如我的問題最後提出的,這是一個與ClassLoader相關的問題。但是,它不是Mule或Spring特定的。這是普通的舊的ClassLoader的可視性原則:

能見度原則讓孩子的類加載器看到父ClassLoader加載的所有類 ,但父類加載器無法看到孩子加載 類。

http://javarevisited.blogspot.com/2012/12/how-classloader-works-in-java.html

在我的情況,2依賴的彈簧庫結束了由單獨的類加載器加載。這就是爲什麼我強烈建議在嚮應用程序添加任何具有compile範圍的庫之前檢查provided依賴關係。如果無法避免歧義,管理ClassLoader的優先級可以是一種選擇(母體第一VS家長最後)