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() 메서드 호출.