EJB-거래

트랜잭션은 ACID 속성을 따르는 단일 작업 항목 단위입니다. ACID는 Atomic, Consistent, Isolated 및 Durable을 나타냅니다.

  • Atomic− 작업 항목 중 하나라도 실패하면 전체 단위가 실패한 것으로 간주됩니다. 성공은 모든 항목이 성공적으로 실행됨을 의미합니다.

  • Consistent − 트랜잭션은 시스템을 일관된 상태로 유지해야합니다.

  • Isolated − 각 트랜잭션은 다른 트랜잭션과 독립적으로 실행됩니다.

  • Durable − 트랜잭션이 실행되거나 커밋 된 경우 시스템 오류가 지속되어야합니다.

EJB 컨테이너 / 서버는 트랜잭션 서버이며 트랜잭션 컨텍스트 전파 및 분산 트랜잭션을 처리합니다. 트랜잭션은 컨테이너 또는 Bean의 코드에서 처리하는 사용자 정의 코드로 관리 할 수 ​​있습니다.

  • Container Managed Transactions −이 유형에서 컨테이너는 트랜잭션 상태를 관리합니다.

  • Bean Managed Transactions −이 유형에서는 개발자가 트랜잭션 상태의 수명주기를 관리합니다.

컨테이너 관리 트랜잭션

EJB 3.0은 EJB 컨테이너가 구현하는 트랜잭션의 다음 속성을 지정했습니다.

  • REQUIRED − 비즈니스 방법이 트랜잭션 내에서 실행되어야 함을 나타냅니다. 그렇지 않으면 해당 방법에 대해 새 트랜잭션이 시작됩니다.

  • REQUIRES_NEW − 비즈니스 방법에 대해 새 트랜잭션이 시작됨을 나타냅니다.

  • SUPPORTS − 비즈니스 방법이 트랜잭션의 일부로 실행됨을 나타냅니다.

  • NOT_SUPPORTED − 거래의 일부로 비즈니스 방법을 실행해서는 안됨을 나타냅니다.

  • MANDATORY − 비즈니스 메소드가 트랜잭션의 일부로 실행됨을 나타냅니다. 그렇지 않으면 예외가 발생합니다.

  • NEVER − 비즈니스 메소드가 트랜잭션의 일부로 실행되면 예외가 발생 함을 나타냅니다.

package com.tutorialspoint.txn.required;
 
import javax.ejb.*
 
@Stateless
@TransactionManagement(TransactionManagementType.CONTAINER)
public class UserDetailBean implements UserDetailRemote {
	
   private UserDetail;

   @TransactionAttribute(TransactionAttributeType.REQUIRED)
   public void createUserDetail() {
      //create user details object
   }
}

createUserDetail () 비즈니스 메소드는 필수 어노테이션을 사용하여 필수화됩니다.

package com.tutorialspoint.txn.required;
 
import javax.ejb.*
 
@Stateless
public class UserSessionBean implements UserRemote {
	
   private User;

   @EJB
   private UserDetailRemote userDetail;

   public void createUser() {
      //create user 
      //...
      //create user details
      userDetail.createUserDetail();
   }
}

createUser () 비즈니스 메서드는 createUserDetail ()을 사용합니다. createUser () 호출 중에 예외가 발생하고 User 객체가 생성되지 않으면 UserDetail 객체도 생성되지 않습니다.

빈 관리 트랜잭션

Bean Managed Transactions에서는 애플리케이션 수준에서 예외를 처리하여 트랜잭션을 관리 할 수 ​​있습니다.

다음은 고려해야 할 핵심 사항입니다.

  • Start − 비즈니스 방식으로 거래를 시작하는시기.

  • Sucess − 트랜잭션이 커밋 될 때 성공 시나리오를 식별합니다.

  • Failed − 트랜잭션이 롤백 될 때 실패 시나리오를 식별합니다.

package com.tutorialspoint.txn.bmt;
 
import javax.annotation.Resource;
import javax.ejb.Stateless;
import javax.ejb.TransactionManagement;
import javax.ejb.TransactionManagementType;
import javax.transaction.UserTransaction;
 
@Stateless
@TransactionManagement(value=TransactionManagementType.BEAN)
public class AccountBean implements AccountBeanLocal {
 
   @Resource
   private UserTransaction userTransaction;

   public void transferFund(Account fromAccount, double fund , 
      Account toAccount) throws Exception{

      try{
         userTransaction.begin();

         confirmAccountDetail(fromAccount);
         withdrawAmount(fromAccount,fund);

         confirmAccountDetail(toAccount);
         depositAmount(toAccount,fund);

         userTransaction.commit();
      }catch (InvalidAccountException exception) {
         userTransaction.rollback();
      }catch (InsufficientFundException exception) {
         userTransaction.rollback();
      }catch (PaymentException exception) {
         userTransaction.rollback();
      }
   }

   private void confirmAccountDetail(Account account) 
      throws InvalidAccountException {
   }

   private void withdrawAmount() throws InsufficientFundException {
   }

   private void depositAmount() throws PaymentException{
   }
}

이 예에서 우리는 UserTransaction 다음을 사용하여 트랜잭션 시작을 표시하는 인터페이스 userTransaction.begin()메서드 호출. 거래 완료를 표시합니다. userTransaction.commit() 메소드를 사용하고 트랜잭션 중에 예외가 발생하면 다음을 사용하여 전체 트랜잭션을 롤백합니다. userTransaction.rollback() 메서드 호출.