찾다
데이터 베이스RedisRedis 트랜잭션을 구현하는 방법


ACID 속성 설명

Atomicity(Atomicity)

트랜잭션의 모든 작업은 데이터베이스에서 분할할 수 없습니다. 모두 완료되거나 아무것도 실행되지 않습니다.

일관성

트랜잭션 실행은 데이터를 한 상태에서 다른 상태로 변환합니다. 트랜잭션이 시작되기 전과 트랜잭션이 끝난 후에는 데이터베이스의 무결성 제약 조건을 위반하지 않습니다.

격리

트랜잭션을 격리하려면 각 읽기/쓰기 트랜잭션의 개체가 다른 트랜잭션의 작업 개체와 분리되어야 합니다. 즉, 트랜잭션이 제출되기 전에 다른 트랜잭션에 표시되지 않아야 합니다.

Durability

데이터베이스가 트랜잭션을 실행한 후 데이터 수정 사항이 지속되고 저장되어야 합니다. 데이터베이스를 재시작할 때 데이터의 값은 수정된 값이어야 합니다.

Redis가 트랜잭션을 구현하는 방법

구현 원칙

Redis 트랜잭션 실행에는 다음과 같은 세 단계가 포함됩니다.

  • 클라이언트는 MULTI 명령을 사용하여 명시적으로 트랜잭션을 시작합니다.

  • 서버는 클라이언트가 보낸 특정 작업(예: 데이터 추가, 삭제, 수정)을 수신하여 트랜잭션에서 실행합니다. 이러한 작업은 Redis 자체에서 제공하는 데이터 읽기 및 쓰기 명령입니다. 이러한 명령은 클라이언트에서 서버로 전송되지만 Redis 인스턴스는 이러한 명령을 명령 대기열에 일시적으로 저장만 하고 즉시 실행하지는 않습니다.

  • EXEC 명령이 수신되어 실행될 때만 Redis는 트랜잭션을 커밋하고 실제로 트랜잭션 대기열에 있는 모든 명령을 실행합니다.

트랜잭션 관련 명령

  • MULTI: 트랜잭션 열기

  • EXEC: 트랜잭션을 제출하고 명령 대기열의 모든 작업 명령을 실행합니다.

  • DISCARD: 트랜잭션을 포기하고 명령 대기열을 지우지만 트랜잭션 롤백을 지원할 수 없습니다.

  • WATCH: 트랜잭션 실행 중에 하나 이상의 키 값이 변경되는지 감지합니다. 변경된 경우 현재 트랜잭션의 실행이 중단됩니다.

Redis 트랜잭션은 어떻게 ACID를 지원합니까?

Redis 트랜잭션은 원자성을 지원합니까?

  • 시나리오 1: 트랜잭션이 큐에 추가될 때 트랜잭션을 실행할 때 오류가 보고되면 Redis는 트랜잭션의 원자성을 보장하기 위해 트랜잭션 실행을 중단합니다.

  • 상황 2: 명령이 대기열에 입력될 때 오류가 보고되지 않지만 실제로 실행될 때 오류가 보고됩니다. 트랜잭션의 원자성을 보장할 수 없습니다.

사례 1에 대한 설명 예

127.0.0.1:6379> multi
OK
127.0.0.1:6379> set t1 v1
QUEUED
127.0.0.1:6379> set t2 v2
QUEUED
127.0.0.1:6379> setget t3
(error) ERR unknown command 'setget'
127.0.0.1:6379> set t4 v4
QUEUED
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get t4
(nil)

설명: exec 명령을 실행하기 전에 구문 오류가 발생하면(존재하지 않는 명령이 사용됨) 명령이 대기열에 추가되면 Redis는 오류를 보고하고 다음을 기록합니다. 오류가 발생하고 Exec 명령이 실행될 때까지 기다립니다. 이후 Redi는 제출된 모든 명령을 거부하고 트랜잭션 실행이 실패합니다. 이 경우 Reid의 트랜잭션은 원자성을 지원할 수 있습니다.

사례 2의 예

127.0.0.1:6379> multi 
OK
127.0.0.1:6379> incr s2
QUEUED
127.0.0.1:6379> set a1 v1
QUEUED
127.0.0.1:6379> set a2 v2
QUEUED
127.0.0.1:6379> exec
1) (error) ERR value is not an integer or out of range
2) OK
3) OK
127.0.0.1:6379> get a2
"v2"

설명: s2의 값은 v2입니다. incr 명령을 실행할 때 incr은 정수 유형 값만 추가할 수 있기 때문에 오류가 보고됩니다. 그러나 이 경우 Redis 트랜잭션은 그렇지 않은 것으로 나타났습니다. 후속 명령은 성공적으로 실행될 수 있으므로 이 경우 트랜잭션의 원자성을 보장할 수 없습니다.

Redis 트랜잭션은 일관성을 지원하나요?

시나리오 1: 명령이 대기열에 추가될 때 오류가 보고됩니다

첫 번째 경우에는 트랜잭션 자체가 포기되므로 트랜잭션의 일관성이 보장될 수 있습니다.

사례 2: 명령을 큐에 추가하면 오류가 보고되지 않지만 실제로 실행하면 오류가 보고됩니다.

두 번째 경우에는 잘못된 명령은 실행되지 않지만 올바른 명령은 정상적으로 실행될 수 있습니다. , 데이터베이스의 일관성은 변경되지 않습니다.

시나리오 3: Exec 실행 명령 Redis 인스턴스 실패
  • Redis 지속성이 RDB로 설정된 경우 트랜잭션 실행 시 생성된 RDB 스냅샷이 실행되지 않으므로 트랜잭션 명령 작업의 결과가 저장되지 않습니다. RDB 스냅샷, 복구를 위해 RDB 스냅샷을 사용할 때 데이터베이스의 데이터도 일관됩니다.

  • Reids 지속성이 AOF로 설정되어 있고 트랜잭션 작업이 AOF 로그에 기록되기 전에 인스턴스가 실패하면 AOF 로그를 사용하여 복원된 데이터베이스 데이터는 일관성이 있습니다. AOF 로그에 일부 작업만 기록된 경우 redis-check-aof를 사용하여 트랜잭션에서 완료된 작업을 지울 수 있으며 복구 후에도 데이터베이스의 일관성이 유지됩니다.

Redis 트랜잭션은 격리를 지원하나요?

Redis 트랜잭션 격리를 달성하려면 watch 명령을 사용해야 합니다. Watch의 원칙은 트랜잭션이 실행되기 전에 하나 이상의 키 변경 사항을 모니터링할 때 트랜잭션이 실행을 위해 EXEC 명령을 호출할 때 WATCH 메커니즘이 먼저 모니터링된 키가 다른 클라이언트에 의해 수정되었는지 여부를 확인한다는 것입니다. 리스너의 값이 수정되면 트랜잭션 격리가 파기되는 것을 방지하기 위해 트랜잭션 실행이 중단됩니다.

예제 설명

클라이언트 1:

127.0.0.1:6379> get blance
"100"
127.0.0.1:6379> watch blance
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby blance 10
QUEUED
127.0.0.1:6379> incrby blance 10
QUEUED
127.0.0.1:6379> exec
(nil)

클라이언트 2:

127.0.0.1:6379> get blance
"100"
127.0.0.1:6379> set blance 90
OK
127.0.0.1:6379> get blance
"90"

설명: 클라이언트 1은 시계를 사용하여 트랜잭션을 시작한 후 잔액 값을 변경하는 작업을 수행하여 다른 클라이언트를 시뮬레이션합니다. 트랜잭션 실행 중에 시계에서 모니터링하는 데이터가 변경된 후 클라이언트 1의 EXEC 명령이 실행되지 않은 것으로 나타났습니다.

Redis 트랜잭션은 지속성을 지원합니까?

Redis 트랜잭션은 지속성을 지원할 수 없습니다. Redis가 RDB 모드를 사용하는 경우 트랜잭션이 실행된 후 다음 RDB 스냅샷이 실행되기 전에 Redis 인스턴스가 충돌하는 경우 트랜잭션에 의해 수정된 데이터가 지속성을 보장할 수 없습니다. Redis는 AOF 모드를 채택하므로 지속성 구성이 no, Everysec 또는 Always인 경우 데이터 손실이 발생할 수 있습니다. 따라서 Redis가 채택하는 지속성 모드에 관계없이 트랜잭션 내구성이 지원되지 않습니다.

위 내용은 Redis 트랜잭션을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Redis vs. SQL 데이터베이스 : 주요 차이점Redis vs. SQL 데이터베이스 : 주요 차이점Apr 25, 2025 am 12:02 AM

Redis와 SQL 데이터베이스의 주요 차이점은 Redis가 고성능 및 유연성 요구 사항에 적합한 메모리 데이터베이스라는 것입니다. SQL 데이터베이스는 관계형 데이터베이스로 복잡한 쿼리 및 데이터 일관성 요구 사항에 적합합니다. 구체적으로, 1) Redis는 고속 데이터 액세스 및 캐싱 서비스를 제공하고 캐싱 및 실시간 데이터 처리에 적합한 여러 데이터 유형을 지원합니다. 2) SQL 데이터베이스는 테이블 구조를 통한 데이터를 관리하고 복잡한 쿼리 및 트랜잭션 처리를 지원하며 데이터 일관성이 필요한 전자 상거래 및 금융 시스템과 같은 시나리오에 적합합니다.

Redis : 데이터 저장소 및 서비스 역할을하는 방법Redis : 데이터 저장소 및 서비스 역할을하는 방법Apr 24, 2025 am 12:08 AM

redisactsasbothadatastoreandaservice.1) asadatastore, itusesin-memorystorageforfastoperations, 지원을 지원합니다

Redis 대 기타 데이터베이스 : 비교 분석Redis 대 기타 데이터베이스 : 비교 분석Apr 23, 2025 am 12:16 AM

redis 与其他数据库相比 与其他数据库相比, 与其他数据库相比 : 1) 速度极快 速度极快 速度极快, 读写操作通常在微秒级别; 2) 支持丰富的数据结构和操作; 3) 灵活的使用场景 3) 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 灵活的使用场景 3) redis 또는 기타 데이터베이스를 선택할 때 특정 요구 사항과 시나리오에 따라 다릅니다. Redis는 고성능 및 저도가 낮은 응용 프로그램에서 잘 수행됩니다.

Redis의 역할 : 데이터 저장 및 관리 기능 탐색Redis의 역할 : 데이터 저장 및 관리 기능 탐색Apr 22, 2025 am 12:10 AM

Redis는 데이터 저장 및 관리에서 핵심적인 역할을하며 여러 데이터 구조 및 지속 메커니즘을 통해 현대 애플리케이션의 핵심이되었습니다. 1) Redis는 문자열, 목록, 컬렉션, 주문 컬렉션 및 해시 테이블과 같은 데이터 구조를 지원하며 캐시 및 복잡한 비즈니스 로직에 적합합니다. 2) RDB와 AOF의 두 가지 지속 방법을 통해 Redis는 신뢰할 수있는 스토리지 및 데이터의 빠른 복구를 보장합니다.

REDIS : NOSQL 개념 이해REDIS : NOSQL 개념 이해Apr 21, 2025 am 12:04 AM

Redis는 대규모 데이터의 효율적인 저장 및 액세스에 적합한 NOSQL 데이터베이스입니다. 1.Redis는 여러 데이터 구조를 지원하는 오픈 소스 메모리 데이터 구조 스토리지 시스템입니다. 2. 캐싱, 세션 관리 등에 적합한 매우 빠른 읽기 및 쓰기 속도를 제공합니다. 3. REDIS는 RDB 및 AOF를 통해 지속성을 지원하고 데이터 보안을 보장합니다. 4. 사용 예제에는 기본 키 값 쌍 작업 및 고급 수집 중복 제거 기능이 포함됩니다. 5. 일반적인 오류에는 연결 문제, 데이터 유형 불일치 및 메모리 오버플로가 포함되므로 디버깅에주의를 기울여야합니다. 6. 성능 최적화 제안에는 적절한 데이터 구조 선택 및 메모리 제거 전략 설정이 포함됩니다.

REDIS : 실제 사용 사례 및 예제REDIS : 실제 사용 사례 및 예제Apr 20, 2025 am 12:06 AM

실제 세계에서 Redis의 애플리케이션에는 다음이 포함됩니다. 1. 캐시 시스템으로서 데이터베이스 쿼리를 가속화, 2. 웹 응용 프로그램의 세션 데이터를 저장하려면 3. 실시간 순위를 구현하려면 메시지 전달을 메시지 큐로 단순화합니다. Redis의 다목적 성과 고성능은 이러한 시나리오에서 빛을 발합니다.

Redis : 기능과 기능을 탐색합니다Redis : 기능과 기능을 탐색합니다Apr 19, 2025 am 12:04 AM

Redis는 고속, 다양성 및 풍부한 데이터 구조로 인해 두드러집니다. 1) Redis는 문자열, 목록, 컬렉션, 해시 및 주문 컬렉션과 같은 데이터 구조를 지원합니다. 2) 메모리를 통해 데이터를 저장하고 RDB 및 AOF 지속성을 지원합니다. 3) Redis 6.0에서 시작하여 멀티 스레드 I/O 작업이 도입되어 동시 동시성 시나리오에서 성능이 향상되었습니다.

Redis는 SQL 또는 NOSQL 데이터베이스입니까? 대답이 설명되었습니다Redis는 SQL 또는 NOSQL 데이터베이스입니까? 대답이 설명되었습니다Apr 18, 2025 am 12:11 AM

redisisclassifiedasanoSqldatabaseBecauseItuseSakey-valuedatamodelinsteadofThraditionalRelationalDatabasemodel.Itoffersspeedandflexibility, makingIdealforreal-timeApplicationsandcaching, butitmaynotbesuitableforscenariosrequiringstrictaintetaintetaintetaintetaintetaintetaintegry

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구