ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 트랜잭션(Transaction) 옵션
    BackEnd/Spring DB 2023. 2. 11. 09:40
    반응형

      스프링 트랜잭션은 다양한 옵션을 제공합니다.

    public @interface Transactional {
        String value() default "";
        String transactionManager() default "";
        
        Class<? extends Throwable>[] rollbackFor() default {};
        Class<? extends Throwable>[] noRollbackFor() default {};
        
        Propagation propagation() default Propagation.REQUIRED;
        Isolation isolation() default Isolation.DEFAULT;
        int timeout() default TransactionDefinition.TIMEOUT_DEFAULT;
     
        boolean readOnly() default false;
        String[] label() default {};
    }

     

    value, transactionManager

      @Transactional에서 트랜잭션 프록시가 사용할 트랜잭션 매니저를 지정할 때 value, transactionManager 둘 중 하나에 트랜잭션 매니저의 스프링 빈 이름을 적어주면 됩니다. 해당 값을 생략하면 기본으로 등록된 트랜잭션 매니저를 사용합니다. 애노테이션에서 속성이 하나인 경우 다음과 같이 value는 생략하고 값을 넣을 수 있습니다.

    public class TxService {
    
        @Transactional("memberTxManager")
        public void member() {...}
        
        @Transactional("orderTxManager")
        public void order() {...}
    }

     

    rollbackFor

      예외 발생 시 스프링 트랜잭션의 기본 정책은 다음과 같습니다.

    • 언체크 예외(복구 불가능한 예외)인 RuntimeException, Error와 그 하위 예외가 발생하면 롤백합니다.
    • 체크 예외(비즈니스 의미가 있을 때 사용)인 Exception과 그 하위 예외들은 커밋합니다.

     

      해당 옵션을 사용하면 기본 정책에 추가로 어떤 예외가 발생할 때 롤백할지 지정할 수 있습니다. 다음은 체크 예외인 Exception과 그 하위 예외가 발생해도 롤백합니다. 

    @Transactional(rollbackFor = Exception.class)

      rollbackFor는 예외 클래스를 직접 지정하고, rollbackForClassName는 예외 이름을 문자로 넣으면 됩니다.

     

    noRollbackFor

      rollbackFor와 반대로 기본 정책에 추가로 어떤 예외가 발생했을 때 롤백하면 안되는지 지정할 수 있습니다.

     

    propagation

      트랜잭션 전파에 대한 옵션입니다. 다음 포스팅에서 정리합니다.

     

    isolation

      트랜잭션 격리 수준을 지정할 때 사용하는 옵션입니다. 기본 값은 데이터베이스에서 설정한 트랜잭션 격리 수준을 사용하는 DEFAULT 입니다. 대부분 데이터베이스에서 설정한 기준을 따르기에 애플리케이션 개발자가 트랜잭션 격리 수준을 직접 지정하는 경우는 드뭅니다.

    • DEFAULT: 데이터베이스에서 설정한 격리 수준
    • READ_UNCOMMITTED: 커밋되지 않은 읽기
    • READ_COMMITTED: 커밋된 읽기
    • REPEATABLE_READ: 반복 가능한 읽기
    • SERIALIZABLE: 직렬화 가능

     

    timeout

      트랜잭션 수행 시간에 대한 타임아웃을 초 단위로 지정합니다. 기본 값은 트랜잭션 시스템의 타임아웃을 사용합니다. 운영 환경에 따라 동작하는 경우도 있고, 그렇지 않은 경우도 있기 때문에 확인하고 사용해야 합니다. timeoutString은 숫자 대신 문자 값으로 지정합니다.

     

    readOnly

      트랜잭션은 기본적으로 읽기, 쓰기가 모두 가능한 트랜잭션이 생성됩니다. readOnly=true 옵션을 사용하면 읽기 전용 트랜잭션이 생성됩니다. 이 경우 등록, 수정, 삭제가 안되고 읽기 기능만 동작하며, 읽기에서 성능 최적화가 발생합니다(드라이버나 데이터베이스에 따라 정상 동작하지 않는 경우도 있습니다).

     

    label

      트랜잭션 애노테이션에 있는 값을 직접 읽어서 어떤 동작을 하고 싶을 때 사용할 수 있습니다.

     

    [참고 정보]

    스프링 DB 2편 - 데이터 접근 핵심 원리

    전체 소스코드

    반응형

    'BackEnd > Spring DB' 카테고리의 다른 글

    트랜잭션 전파(propagation)  (0) 2023.02.15
    트랜잭션(Transaction) 심화  (0) 2023.02.11
    데이터 접근 기술- 활용  (0) 2023.02.09
    데이터 접근 기술- QueryDSL  (0) 2023.02.04
    데이터 접근 기술- Spring Data JPA  (0) 2023.02.04

    댓글

Designed by Tistory.