봄-트랜잭션 관리

데이터베이스 트랜잭션은 단일 작업 단위로 처리되는 일련의 작업입니다. 이러한 작업은 완전히 완료되거나 전혀 효과가 없어야합니다. 트랜잭션 관리는 데이터 무결성과 일관성을 보장하기위한 RDBMS 지향 엔터프라이즈 애플리케이션의 중요한 부분입니다. 트랜잭션의 개념은 다음과 같은 네 가지 주요 속성으로 설명 할 수 있습니다.ACID

  • Atomicity − 트랜잭션은 단일 작업 단위로 취급되어야합니다. 즉, 전체 작업 순서가 성공하거나 실패했음을 의미합니다.

  • Consistency − 이는 데이터베이스의 참조 무결성, 테이블의 고유 한 기본 키 등의 일관성을 나타냅니다.

  • Isolation− 동시에 동일한 데이터 세트로 많은 트랜잭션 처리가있을 수 있습니다. 데이터 손상을 방지하려면 각 트랜잭션을 다른 트랜잭션과 격리해야합니다.

  • Durability − 트랜잭션이 완료되면이 트랜잭션의 결과는 영구적이어야하며 시스템 오류로 인해 데이터베이스에서 지울 수 없습니다.

실제 RDBMS 데이터베이스 시스템은 각 트랜잭션에 대해 네 가지 속성을 모두 보장합니다. SQL을 사용하여 데이터베이스에 발행 된 트랜잭션의 단순한보기는 다음과 같습니다.

  • begin transaction 명령을 사용하여 트랜잭션을 시작합니다 .

  • SQL 쿼리를 사용하여 다양한 삭제, 업데이트 또는 삽입 작업을 수행합니다.

  • 모든 작업이 성공하면 커밋 을 수행하고 그렇지 않으면 모든 작업을 롤백 합니다.

Spring 프레임 워크는 다양한 기본 트랜잭션 관리 API 위에 추상 레이어를 제공합니다. Spring의 트랜잭션 지원은 POJO에 트랜잭션 기능을 추가하여 EJB 트랜잭션에 대한 대안을 제공하는 것을 목표로합니다. Spring은 프로그래밍 및 선언적 트랜잭션 관리를 모두 지원합니다. EJB에는 애플리케이션 서버가 필요하지만 애플리케이션 서버 없이도 Spring 트랜잭션 관리를 구현할 수 있습니다.

로컬 대 글로벌 트랜잭션

로컬 트랜잭션은 JDBC 연결과 같은 단일 트랜잭션 리소스에 특정한 반면 전역 트랜잭션은 분산 시스템의 트랜잭션과 같은 여러 트랜잭션 리소스에 걸쳐있을 수 있습니다.

로컬 트랜잭션 관리는 응용 프로그램 구성 요소와 리소스가 단일 사이트에있는 중앙 집중식 컴퓨팅 환경에서 유용 할 수 있으며 트랜잭션 관리에는 단일 시스템에서 실행되는 로컬 데이터 관리자 만 포함됩니다. 로컬 트랜잭션은 구현하기가 더 쉽습니다.

모든 리소스가 여러 시스템에 분산되어있는 분산 컴퓨팅 환경에서는 글로벌 트랜잭션 관리가 필요합니다. 이러한 경우 트랜잭션 관리는 로컬 및 글로벌 수준에서 수행되어야합니다. 분산 또는 글로벌 트랜잭션은 여러 시스템에서 실행되며, 그 실행에는 글로벌 트랜잭션 관리 시스템과 관련된 모든 시스템의 모든 로컬 데이터 관리자 간의 조정이 필요합니다.

프로 그래 매틱 vs. 선언

Spring은 두 가지 유형의 트랜잭션 관리를 지원합니다.

  • 프로그래밍 방식의 트랜잭션 관리 -이것은 프로그래밍의 도움으로 트랜잭션을 관리해야 함을 의미합니다. 그것은 당신에게 극도의 유연성을 제공하지만 유지하기가 어렵습니다.

  • 선언적 트랜잭션 관리 -이것은 비즈니스 코드에서 트랜잭션 관리를 분리하는 것을 의미합니다. 주석 또는 XML 기반 구성 만 사용하여 트랜잭션을 관리합니다.

선언적 트랜잭션 관리는 코드를 통해 트랜잭션을 제어 할 수있는 프로그래밍 방식 트랜잭션 관리보다 덜 유연하지만 프로그래밍 방식 트랜잭션 관리보다 선호됩니다. 그러나 일종의 교차 문제로 선언적 트랜잭션 관리는 AOP 접근 방식으로 모듈화 될 수 있습니다. Spring은 Spring AOP 프레임 워크를 통해 선언적 트랜잭션 관리를 지원합니다.

스프링 트랜잭션 추상화

Spring 트랜잭션 추상화에 대한 키 는 다음과 같이 org.springframework.transaction.PlatformTransactionManager 인터페이스에 의해 정의됩니다.

public interface PlatformTransactionManager {
   TransactionStatus getTransaction(TransactionDefinition definition);
   throws TransactionException;
   
   void commit(TransactionStatus status) throws TransactionException;
   void rollback(TransactionStatus status) throws TransactionException;
}

Sr. 아니요 방법 및 설명
1

TransactionStatus getTransaction(TransactionDefinition definition)

이 메서드는 지정된 전파 동작에 따라 현재 활성 트랜잭션을 반환하거나 새 트랜잭션을 만듭니다.

2

void commit(TransactionStatus status)

이 메소드는 상태와 관련하여 주어진 트랜잭션을 커밋합니다.

void rollback(TransactionStatus status)

이 메소드는 주어진 트랜잭션의 롤백을 수행합니다.

TransactionDefinition는 봄의 트랜잭션 지원의 핵심 인터페이스이며 다음과 같이 정의된다 -

public interface TransactionDefinition {
   int getPropagationBehavior();
   int getIsolationLevel();
   String getName();
   int getTimeout();
   boolean isReadOnly();
}

Sr. 아니요 방법 및 설명
1

int getPropagationBehavior()

이 메서드는 전파 동작을 반환합니다. Spring은 EJB CMT에서 익숙한 모든 트랜잭션 전파 옵션을 제공합니다.

2

int getIsolationLevel()

이 메소드는이 트랜잭션이 다른 트랜잭션의 작업에서 분리되는 정도를 리턴합니다.

String getName()

이 메서드는이 트랜잭션의 이름을 반환합니다.

4

int getTimeout()

이 메서드는 트랜잭션이 완료되어야하는 시간 (초)을 반환합니다.

5

boolean isReadOnly()

이 메서드는 트랜잭션이 읽기 전용인지 여부를 반환합니다.

다음은 격리 수준의 가능한 값입니다.

Sr. 아니요 격리 및 설명
1

TransactionDefinition.ISOLATION_DEFAULT

이것이 기본 격리 수준입니다.

2

TransactionDefinition.ISOLATION_READ_COMMITTED

더티 읽기가 방지됨을 나타냅니다. 반복 불가능한 읽기 및 팬텀 읽기가 발생할 수 있습니다.

TransactionDefinition.ISOLATION_READ_UNCOMMITTED

더티 읽기, 반복 불가능한 읽기 및 팬텀 읽기가 발생할 수 있음을 나타냅니다.

4

TransactionDefinition.ISOLATION_REPEATABLE_READ

더티 읽기 및 반복 불가능한 읽기가 방지됨을 나타냅니다. 팬텀 읽기가 발생할 수 있습니다.

5

TransactionDefinition.ISOLATION_SERIALIZABLE

더티 읽기, 반복 불가능한 읽기 및 팬텀 읽기가 금지됨을 나타냅니다.

다음은 전파 유형에 대한 가능한 값입니다.

Sr. 아니. 전파 및 설명
1

TransactionDefinition.PROPAGATION_MANDATORY

현재 트랜잭션을 지원합니다. 현재 트랜잭션이 없으면 예외가 발생합니다.

2

TransactionDefinition.PROPAGATION_NESTED

현재 트랜잭션이있는 경우 중첩 된 트랜잭션 내에서 실행됩니다.

TransactionDefinition.PROPAGATION_NEVER

현재 거래를 지원하지 않습니다. 현재 트랜잭션이있는 경우 예외를 throw합니다.

4

TransactionDefinition.PROPAGATION_NOT_SUPPORTED

현재 거래를 지원하지 않습니다. 오히려 항상 비 트랜잭션 방식으로 실행합니다.

5

TransactionDefinition.PROPAGATION_REQUIRED

현재 트랜잭션을 지원합니다. 존재하지 않는 경우 새로 만듭니다.

6

TransactionDefinition.PROPAGATION_REQUIRES_NEW

새 트랜잭션을 만들고 현재 트랜잭션이 있으면 일시 중단합니다.

7

TransactionDefinition.PROPAGATION_SUPPORTS

현재 트랜잭션을 지원합니다. 존재하지 않으면 비 트랜잭션 방식으로 실행됩니다.

8

TransactionDefinition.TIMEOUT_DEFAULT

기본 트랜잭션 시스템의 기본 제한 시간을 사용하거나 제한 시간이 지원되지 않는 경우 없음을 사용합니다.

위해 TransactionStatus 인터페이스는 제어 트랜잭션 실행과 쿼리 트랜잭션 상태에 트랜잭션 코드를 작성하기위한 간단한 방법을 제공합니다.

public interface TransactionStatus extends SavepointManager {
   boolean isNewTransaction();
   boolean hasSavepoint();
   void setRollbackOnly();
   boolean isRollbackOnly();
   boolean isCompleted();
}

Sr. 아니. 방법 및 설명
1

boolean hasSavepoint()

이 메소드는이 트랜잭션이 내부적으로 저장 점을 전달하는지, 즉 저장 점을 기반으로 중첩 된 트랜잭션으로 생성되었는지 여부를 반환합니다.

2

boolean isCompleted()

이 메서드는이 트랜잭션이 완료되었는지 여부, 즉 이미 커밋되었는지 롤백되었는지 여부를 반환합니다.

boolean isNewTransaction()

이 메서드는 현재 트랜잭션이 새로운 경우 true를 반환합니다.

4

boolean isRollbackOnly()

이 메서드는 트랜잭션이 롤백 전용으로 표시되었는지 여부를 반환합니다.

5

void setRollbackOnly()

이 메서드는 트랜잭션을 롤백 전용으로 설정합니다.