Spring 트랜잭션 원칙에 대한 자세한 소개
1. 트랜잭션의 기본 원칙
Spring 트랜잭션의 본질은 실제로 데이터베이스의 트랜잭션 지원이 없으면 Spring에서는 트랜잭션 기능을 제공할 수 없습니다. 순수 JDBC 운영 데이터베이스의 경우 트랜잭션을 사용하려면 다음 단계를 수행하면 됩니다.
연결 가져오기 Connection con = DriverManager.getConnection()
트랜잭션 열기 con.setAutoCommit(true/false);
CRUD 실행
커밋 트랜잭션/롤백 트랜잭션 con.commit () / con.rollback();
연결을 닫습니다. conn.close();
Spring의 트랜잭션 관리 기능을 사용한 후, 그런 다음 2단계와 4단계의 코드를 작성하면 Spirng 그러면 Spring은 우리가 작성한 CRUD 전후에 어떻게 트랜잭션을 열고 닫을 수 있을까요? 이 문제를 해결하기 위해 Spring의 트랜잭션 관리 구현 원리를 전체적으로 이해할 수 있습니다 . <.>
- 구성 파일
주석 활성화Driver, @Transactional 주석
으로 관련 클래스 및 메서드 표시 Spring은 시작 시 관련 Bean을 구문 분석하고 생성하며 관련 주석이 있는 클래스와 메서드를 확인하고 이러한 클래스와 메서드에 대한 프록시를 생성하며 @Transaction의 관련 매개변수에 따라 관련 구성을 주입합니다. , 에이전트가 관련 트랜잭션을 처리하도록 합니다(일반 트랜잭션 제출 및 예외 롤백 활성화) - 실제 데이터베이스 계층 트랜잭션 제출 및 롤백은 binlog 또는 로그 구현을 통해 이루어집니다.
- 2. Spring 트랜잭션 전파 속성
소위 Spring 트랜잭션의 전파 속성은 동시에 여러 트랜잭션이 있을 때 정의됩니다. . Spring이 이러한 트랜잭션의 동작을 처리하는 방법은 TransactionDefinition에 정의되어 있습니다. 특정 상수
에 대한 설명은상수 이름 | 상수 설명 |
PROPAGATION_REQUIRED | 현재 트랜잭션을 지원합니다. 현재 트랜잭션이 없으면 새 트랜잭션을 생성하세요. . 이것은 가장 일반적인 선택이며 Spring의 기본 트랜잭션 전파입니다. |
PROPAGATION_REQUIRES_NEW | 새 거래(현재 있는 경우) 거래, 현재 거래를 일시 중단합니다. 새로 생성된 트랜잭션은 일시 중단된 트랜잭션과 아무런 관련이 없습니다. 이는 두 개의 독립적인 트랜잭션입니다. 외부 트랜잭션이 실패하고 롤백된 후에는 내부 트랜잭션 실행 결과를 롤백할 수 없습니다. 예외를 발생시킵니다, 외부 트랜잭션에 의해 캡처되거나 롤백 작업을 처리하지 않습니다 |
PROPAGATION_SUPPORTS | 현재 거래가 없는 경우 현재 거래를 지원합니다. , 비트랜잭션 방식으로 실행됩니다. |
PROPAGATION_MANDATORY | 현재 거래가 없는 경우 지원합니다. 현재 트랜잭션에서는 예외가 발생합니다. |
PROPAGATION_NOT_SUPPORTED | 비트랜잭션 방식으로 작업 수행 if 현재 트랜잭션이 있는 경우 현재 트랜잭션이 일시 중지됩니다. |
PROPAGATION_NEVER | 다음의 경우 비트랜잭션 모드에서 실행합니다. 현재 트랜잭션이 존재하는 경우 예외가 발생합니다. |
PROPAGATION_NESTED | 활성 트랜잭션이 있으면 중첩된 트랜잭션에서 실행됩니다. 활성 트랜잭션이 없으면 REQUIRED 속성이 실행됩니다. 롤백할 수 있는 여러 저장점이 있는 단일 트랜잭션을 사용합니다. 내부 트랜잭션 롤백은 외부 트랜잭션에 영향을 미치지 않습니다. DataSourceTransactionManager 트랜잭션 관리자에서만 작동합니다. |
3. 데이터베이스 격리 수준
隔离级别 | 隔离级别的值 | 导致的问题 |
Read-Uncommitted | 0 | 导致脏读 |
Read-Committed | 1 | 避免脏读,允许不可重复读和幻读 |
Repeatable-Read | 2 | 避免脏读,不可重复读,允许幻读 |
Serializable | 3 | 串行化读,事务只能一个一个执行,避免了脏读、不可重复读、幻读。执行效率慢,使用时慎重 |
더티 읽기(Dirty read): 하나의 트랜잭션이 데이터를 추가, 삭제 또는 수정했지만 제출되지 않았습니다. 커밋되지 않은 데이터를 읽을 수 있습니다. 이때 첫 번째 트랜잭션이 롤백되면 두 번째 트랜잭션에서 더티 데이터를 읽게 됩니다.
반복 불가능한 읽기: 한 트랜잭션에서 두 번의 읽기 작업이 발생했습니다. 첫 번째 읽기 작업과 두 번째 작업 사이에 다른 트랜잭션이 데이터를 수정했습니다. 이때 두 번 읽은 데이터가 일치하지 않습니다.
팬텀 읽기: 첫 번째 트랜잭션은 특정 범위의 데이터에 대한 수정을 일괄 처리하고 두 번째 트랜잭션은 이 범위에 데이터 조각을 추가합니다. 이때 첫 번째 트랜잭션은 새로 추가된 데이터의 수정 사항을 잃게 됩니다. .
요약:
격리 수준이 높을수록 데이터의 완전성과 일관성이 보장되지만 동시성 성능에 미치는 영향은 더 커집니다.
SqlServer, Oracle과 같은 대부분의 데이터베이스의 기본 격리 수준은 Read Commited입니다.
일부 데이터베이스의 기본 격리 수준은 다음과 같습니다. MySQL과 같은 반복 읽기 InnoDB
4. Spring의 격리 수준
常量 | 解释 |
ISOLATION_DEFAULT | 这是个 PlatfromTransactionManager 默认的隔离级别,使用数据库默认的事务隔离级别。另外四个与 JDBC 的隔离级别相对应。 |
ISOLATION_READ_UNCOMMITTED | 这是事务最低的隔离级别,它充许另外一个事务可以看到这个事务未提交的数据。这种隔离级别会产生脏读,不可重复读和幻像读。 |
ISOLATION_READ_COMMITTED | 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据。 |
ISOLATION_REPEATABLE_READ | 这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。 |
ISOLATION_SERIALIZABLE | 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。 |
5. 트랜잭션 중첩
위의 이론적 지식을 통해 데이터베이스 트랜잭션과 스프링 트랜잭션의 일부 속성과 특성을 대략적으로 이해했습니다. 다음으로 몇 가지 중첩 트랜잭션 시나리오를 분석하여 스프링 트랜잭션 전파 메커니즘.
외부 트랜잭션 서비스 A의 메서드 A()가 내부 서비스 B의 메서드 B()를 호출한다고 가정합니다.
PROPAGATION_REQUIRED(봄 기본값)
If ServiceB.methodB()의 트랜잭션 수준이 PROPAGATION_REQUIRED로 정의되어 있으면 ServiceA.methodA()를 실행할 때 Spring이 이미 트랜잭션을 시작했으며 이때 ServiceB.methodB()가 호출되고 ServiceB.methodB()가 이를 확인합니다. ServiceA에서 이미 실행 중입니다. methodA() 트랜잭션 내에서는 새 트랜잭션이 시작되지 않습니다.
ServiceB.methodB()가 실행 중일 때 트랜잭션에 없는 것을 발견하면 자체적으로 트랜잭션을 할당합니다.
이런 방식으로 ServiceA.methodA() 또는 ServiceB.methodB() 내 어디에서나 예외가 발생하면 트랜잭션이 롤백됩니다.
PROPAGATION_REQUIRES_NEW
예를 들어 ServiceA.methodA()의 트랜잭션 수준은 PROPAGATION_REQUIRED로, ServiceB.methodB()의 트랜잭션 수준은 PROPAGATION_REQUIRES_NEW로 설계합니다. .
그런 다음 ServiceB.methodB()가 실행되면 ServiceA.methodA()가 있는 트랜잭션이 일시 중지되고 ServiceB.methodB()는 ServiceB.methodB()를 기다리면서 새 트랜잭션을 시작합니다. 트랜잭션이 완료되면 실행이 계속됩니다.
PROPAGATION_REQUIRED와 차이점은 트랜잭션 롤백 정도입니다. ServiceB.methodB()가 새 트랜잭션을 시작하기 때문에 두 가지 다른 트랜잭션이 있습니다. ServiceB.methodB()가 제출된 경우 ServiceA.methodA()는 실패하고 롤백되지만 ServiceB.methodB()는 롤백되지 않습니다. ServiceB.methodB()가 롤백에 실패하고 발생한 예외가 ServiceA.methodA()에 의해 포착되면 ServiceA.methodA() 트랜잭션이 계속 제출될 수 있습니다. 이는 주로 B에서 발생한 예외가 다음과 같은 예외인지 여부에 따라 달라집니다. A는 롤백됩니다).
PROPAGATION_SUPPORTS
ServiceB.methodB()의 트랜잭션 수준이 PROPAGATION_SUPPORTS라고 가정하고 ServiceB.methodB()가 실행될 때 ServiceA가 발견되면. methodA()가 열려 있으면 현재 트랜잭션에 참여합니다. ServiceA.methodA()가 트랜잭션을 열지 않는 것으로 확인되면 트랜잭션 자체를 열지 않습니다. 이때 내부 메소드의 트랜잭션성은 가장 외부 트랜잭션에 전적으로 의존합니다.
PROPAGATION_NESTED
이제 상황은 더욱 복잡해집니다. ServiceB.methodB()의 트랜잭션 속성은 PROPAGATION_NESTED로 구성됩니다. ? ServiceB#methodB 롤백되는 경우 내부 트랜잭션(예: ServiceB#methodB)은 실행되기 전에 SavePoint로 롤백되는 반면, 외부 트랜잭션(예: ServiceA#methodA)은 다음 두 가지 방법으로 처리될 수 있습니다. 🎜>
a. 예외 캡처 및 예외 분기 논리 실행void methodA() { try { ServiceB.methodB(); } catch (SomeException) { // 执行其他业务, 如 ServiceC.methodC(); } }
위 내용은 Spring 트랜잭션 원칙에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











2023년에는 AI 기술이 화두가 되면서 다양한 산업, 특히 프로그래밍 분야에 큰 영향을 미치고 있다. 사람들은 AI 기술의 중요성을 점점 더 인식하고 있으며 Spring 커뮤니티도 예외는 아닙니다. GenAI(일반 인공 지능) 기술이 지속적으로 발전함에 따라 AI 기능을 갖춘 애플리케이션 생성을 단순화하는 것이 중요하고 시급해졌습니다. 이러한 배경에서 AI 기능 애플리케이션 개발 프로세스를 단순화하고 간단하고 직관적이며 불필요한 복잡성을 피하는 것을 목표로 하는 "SpringAI"가 등장했습니다. 'SpringAI'를 통해 개발자는 AI 기능이 포함된 애플리케이션을 더욱 쉽게 구축할 수 있어 사용 및 운영이 더욱 쉬워진다.

업계 리더인 Spring+AI는 강력하고 유연한 API와 고급 기능을 통해 다양한 산업에 선도적인 솔루션을 제공합니다. 이 주제에서는 다양한 분야의 Spring+AI 적용 사례를 살펴보겠습니다. 각 사례에서는 Spring+AI가 어떻게 특정 요구 사항을 충족하고 목표를 달성하며 이러한 LESSONSLEARNED를 더 넓은 범위의 애플리케이션으로 확장하는지 보여줍니다. 이 주제가 여러분이 Spring+AI의 무한한 가능성을 더 깊이 이해하고 활용하는 데 영감을 줄 수 있기를 바랍니다. Spring 프레임워크는 소프트웨어 개발 분야에서 20년 이상의 역사를 가지고 있으며, Spring Boot 1.0 버전이 출시된 지 10년이 되었습니다. 이제 봄이 왔다는 것에 대해 누구도 이의를 제기할 수 없습니다.

Spring 프로그래밍 방식 트랜잭션을 구현하는 방법: 1. TransactionCallback 및 TransactionCallbackWithoutResult를 사용합니다. 3. Transactional 주석을 사용합니다. 4. @Transactional과 함께 TransactionTemplate을 사용합니다.

Java는 예약된 작업을 구현합니다. Jdk와 함께 제공되는 라이브러리에는 예약된 작업을 구현하는 두 가지 방법이 있습니다. 하나는 Timer이고 다른 하나는 ScheduledThreadPoolExecutor입니다. Timer+TimerTask가 Timer를 생성하면 TimerTask 작업을 예약하는 데 사용할 수 있는 스레드가 생성됩니다. Timer에는 4가지 구성 방법이 있으며, Timer 스레드의 이름과 데몬 스레드로 설정할지 여부를 지정할 수 있습니다. 기본 이름은 Timer-number이고 기본값은 데몬 스레드가 아닙니다. 주로 세 가지 중요한 메서드가 있습니다. cancel(): 작업 예약을 종료하고 현재 예약된 모든 작업을 취소합니다. purge(): 작업 대기열에서 작업을 제거합니다.

SpringBoot와 SpringCloud는 모두 개발자가 마이크로서비스 애플리케이션을 더 빠르게 구축하고 배포하는 데 도움이 되는 Spring Framework의 확장이지만 각각 다른 목적과 기능을 가지고 있습니다. SpringBoot는 Java 애플리케이션을 빠르게 구축하기 위한 프레임워크로, 개발자가 Spring 기반 애플리케이션을 더 빠르게 생성하고 배포할 수 있도록 해줍니다. 독립 실행형 실행 가능한 Spring 애플리케이션을 구축하는 간단하고 이해하기 쉬운 방법을 제공합니다.

Spring에서 트랜잭션 격리 수준을 설정하는 방법: 1. @Transactional 주석을 사용합니다. 2. Spring 구성 파일에서 설정합니다. 3. PlatformTransactionManager를 사용합니다. 4. Java 구성 클래스에서 설정합니다. 자세한 소개: 1. @Transactional 주석을 사용하고, 트랜잭션 관리가 필요한 클래스나 메소드에 @Transactional 주석을 추가하고, 속성에서 격리 수준을 설정합니다. 2. Spring 구성 파일에서 등.

기술의 업데이트와 반복으로 Java5.0은 주석을 지원하기 시작했습니다. Java의 선도적인 프레임워크인 Spring은 버전 2.5로 업데이트된 이후 천천히 xml 구성을 포기하기 시작했으며 더 많은 주석이 spring 프레임워크를 제어하는 데 사용됩니다.

Java 개발자로서 Spring 프레임워크를 배우고 사용하는 것은 필수적인 기술입니다. 클라우드 컴퓨팅과 마이크로서비스의 인기로 인해 Spring Cloud를 배우고 사용하는 것은 반드시 숙달해야 하는 또 다른 기술이 되었습니다. SpringCloud는 분산 시스템을 빠르게 구축하기 위한 SpringBoot 기반 개발 도구 세트입니다. 개발자에게 서비스 등록 및 검색, 구성 센터, 로드 밸런싱 및 회로 차단기 등을 포함한 일련의 구성 요소를 제공하여 개발자가 마이크로 구축을 가능하게 합니다.
