2012-11-22 3 views
0

두 개의 stateless EJB가 있습니다. 하나는 컨테이너 관리 트랜잭션을 사용하고 다른 하나는 빈을 관리합니다. 컨테이너 관리 EJB에서 빈 관리 EJB 메소드를 호출합니다.Java, JPA, bean 관리 트랜잭션, TransactionRequiredException

public class firstEJB{ 
    public void myMethod(){ 
     ejb.longRunningMethod(); 
    } 

    @EJB 
    private secondEJB ejb; 
} 


@TransactionManagement(TransactionManagementType.BEAN) 
public class secondEJB { 
    public void longRunningMethod(){ 
     while (true) { 
      this.ut.begin(); 
      //do smth 
      this.ut.commit(); 
     } 
    } 

    @Resource 
    private UserTransaction ut; 
} 

나는 오류

Caused by: javax.persistence.TransactionRequiredException: 
Exception Description: No externally managed transaction is currently active for this thread 
at org.eclipse.persistence.internal.jpa.transaction.JTATransactionWrapper.throwCheckTransactionFailedException(JTATransactionWrapper.java:86) 
at org.eclipse.persistence.internal.jpa.transaction.JTATransactionWrapper.checkForTransaction(JTATransactionWrapper.java:46) 
at org.eclipse.persistence.internal.jpa.EntityManagerImpl.checkForTransaction(EntityManagerImpl.java:1776) 
at org.eclipse.persistence.internal.jpa.EJBQueryImpl.executeReadQuery(EJBQueryImpl.java:449) 
at org.eclipse.persistence.internal.jpa.EJBQueryImpl.getResultList(EJBQueryImpl.java:742) 
at com.sun.enterprise.container.common.impl.QueryWrapper.getResultList(QueryWrapper.java:195) 
at com.sun.enterprise.container.common.impl.TypedQueryWrapper.getResultList(TypedQueryWrapper.java:129) 
at VIGS.Statistics.DataProcessor.secondEJB.longRunningMethod(secondEJB.java:34) 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:601) 
at org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1052) 
at org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1124) 
at com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:5388) 
at com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:619) 
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800) 
at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:571) 
at org.jboss.weld.ejb.SessionBeanInterceptor.aroundInvoke(SessionBeanInterceptor.java:42) 
at sun.reflect.GeneratedMethodAccessor69.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:601) 
at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:861) 
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800) 
at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:571) 
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.doAround(SystemInterceptorProxy.java:162) 
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.aroundInvoke(SystemInterceptorProxy.java:144) 
at sun.reflect.GeneratedMethodAccessor68.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:601) 
at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:861) 
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800) 
at com.sun.ejb.containers.interceptors.InterceptorManager.intercept(InterceptorManager.java:370) 
at com.sun.ejb.containers.BaseContainer.__intercept(BaseContainer.java:5360) 
at com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:5348) 
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:214) 
... 42 more 

내가 컨테이너 관리 EJB에서 빈 관리 트랜잭션와 EJB의 메소드를 호출 할 수있어? 예인 경우 - 무엇이 잘못 되었나요?

P. 내가 라인 (34)에 오류가있어이이 줄의 코드 :

while ((lf = this.em.createNamedQuery("getNotProcessedLogFiles", LogFile.class).setMaxResults(0).setLockMode(LockModeType.PESSIMISTIC_WRITE).getResultList().get(0)) != null) { 

답변

0

모든 것이 아주 쉬웠다 - 내 while 루프에서 나는 잠금 모드가 을 LockModeType.PESSIMISTIC_WRITE 설정하려고하지만 우리는 그것을 할 수 있습니다 거래 내에서만 ...