목차
ACID 속성 설명
Atomicity(Atomicity)
일관성
격리
Durability
Redis가 트랜잭션을 구현하는 방법
구현 원칙
트랜잭션 관련 명령
Redis 트랜잭션은 어떻게 ACID를 지원합니까?
Redis 트랜잭션은 원자성을 지원합니까?
Redis 트랜잭션은 일관성을 지원하나요?
시나리오 1: 명령이 대기열에 추가될 때 오류가 보고됩니다
사례 2: 명령을 큐에 추가하면 오류가 보고되지 않지만 실제로 실행하면 오류가 보고됩니다.
시나리오 3: Exec 실행 명령 Redis 인스턴스 실패
Redis 트랜잭션은 격리를 지원하나요?
Redis 트랜잭션은 지속성을 지원합니까?
데이터 베이스 Redis Redis 트랜잭션을 구현하는 방법

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

May 26, 2023 pm 12:31 PM
redis


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으로 문의하세요.

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Redis 클러스터 모드를 구축하는 방법 Redis 클러스터 모드를 구축하는 방법 Apr 10, 2025 pm 10:15 PM

Redis Cluster Mode는 Sharding을 통해 Redis 인스턴스를 여러 서버에 배포하여 확장 성 및 가용성을 향상시킵니다. 시공 단계는 다음과 같습니다. 포트가 다른 홀수 redis 인스턴스를 만듭니다. 3 개의 센티넬 인스턴스를 만들고, Redis 인스턴스 및 장애 조치를 모니터링합니다. Sentinel 구성 파일 구성, Redis 인스턴스 정보 및 장애 조치 설정 모니터링 추가; Redis 인스턴스 구성 파일 구성, 클러스터 모드 활성화 및 클러스터 정보 파일 경로를 지정합니다. 각 redis 인스턴스의 정보를 포함하는 Nodes.conf 파일을 작성합니다. 클러스터를 시작하고 Create 명령을 실행하여 클러스터를 작성하고 복제본 수를 지정하십시오. 클러스터에 로그인하여 클러스터 정보 명령을 실행하여 클러스터 상태를 확인하십시오. 만들다

Redis 데이터를 지우는 방법 Redis 데이터를 지우는 방법 Apr 10, 2025 pm 10:06 PM

Redis 데이터를 지우는 방법 : Flushall 명령을 사용하여 모든 키 값을 지우십시오. FlushDB 명령을 사용하여 현재 선택한 데이터베이스의 키 값을 지우십시오. 선택을 사용하여 데이터베이스를 전환 한 다음 FlushDB를 사용하여 여러 데이터베이스를 지우십시오. del 명령을 사용하여 특정 키를 삭제하십시오. Redis-Cli 도구를 사용하여 데이터를 지우십시오.

Redis 대기열을 읽는 방법 Redis 대기열을 읽는 방법 Apr 10, 2025 pm 10:12 PM

Redis의 대기열을 읽으려면 대기열 이름을 얻고 LPOP 명령을 사용하여 요소를 읽고 빈 큐를 처리해야합니다. 특정 단계는 다음과 같습니다. 대기열 이름 가져 오기 : "큐 :"와 같은 "대기열 : my-queue"의 접두사로 이름을 지정하십시오. LPOP 명령을 사용하십시오. 빈 대기열 처리 : 대기열이 비어 있으면 LPOP이 NIL을 반환하고 요소를 읽기 전에 대기열이 존재하는지 확인할 수 있습니다.

Redis 명령을 사용하는 방법 Redis 명령을 사용하는 방법 Apr 10, 2025 pm 08:45 PM

Redis 지시 사항을 사용하려면 다음 단계가 필요합니다. Redis 클라이언트를 엽니 다. 명령 (동사 키 값)을 입력하십시오. 필요한 매개 변수를 제공합니다 (명령어마다 다름). 명령을 실행하려면 Enter를 누르십시오. Redis는 작업 결과를 나타내는 응답을 반환합니다 (일반적으로 OK 또는 -err).

Redis Lock을 사용하는 방법 Redis Lock을 사용하는 방법 Apr 10, 2025 pm 08:39 PM

Redis를 사용하여 잠금 작업을 사용하려면 SetNX 명령을 통해 잠금을 얻은 다음 만료 명령을 사용하여 만료 시간을 설정해야합니다. 특정 단계는 다음과 같습니다. (1) SETNX 명령을 사용하여 키 값 쌍을 설정하십시오. (2) 만료 명령을 사용하여 잠금의 만료 시간을 설정하십시오. (3) DEL 명령을 사용하여 잠금이 더 이상 필요하지 않은 경우 잠금을 삭제하십시오.

Centos redis에서 lua 스크립트 실행 시간을 구성하는 방법 Centos redis에서 lua 스크립트 실행 시간을 구성하는 방법 Apr 14, 2025 pm 02:12 PM

CentOS 시스템에서는 Redis 구성 파일을 수정하거나 Redis 명령을 사용하여 악의적 인 스크립트가 너무 많은 리소스를 소비하지 못하게하여 LUA 스크립트의 실행 시간을 제한 할 수 있습니다. 방법 1 : Redis 구성 파일을 수정하고 Redis 구성 파일을 찾으십시오. Redis 구성 파일은 일반적으로 /etc/redis/redis.conf에 있습니다. 구성 파일 편집 : 텍스트 편집기 (예 : VI 또는 Nano)를 사용하여 구성 파일을 엽니 다. Sudovi/etc/redis/redis.conf LUA 스크립트 실행 시간 제한을 설정 : 구성 파일에서 다음 줄을 추가 또는 수정하여 LUA 스크립트의 최대 실행 시간을 설정하십시오 (Unit : Milliseconds).

Redis 명령 줄을 사용하는 방법 Redis 명령 줄을 사용하는 방법 Apr 10, 2025 pm 10:18 PM

Redis Command Line 도구 (Redis-Cli)를 사용하여 다음 단계를 통해 Redis를 관리하고 작동하십시오. 서버에 연결하고 주소와 포트를 지정하십시오. 명령 이름과 매개 변수를 사용하여 서버에 명령을 보냅니다. 도움말 명령을 사용하여 특정 명령에 대한 도움말 정보를 봅니다. 종금 명령을 사용하여 명령 줄 도구를 종료하십시오.

Debian Readdir의 성능을 최적화하는 방법 Debian Readdir의 성능을 최적화하는 방법 Apr 13, 2025 am 08:48 AM

Debian Systems에서 ReadDir 시스템 호출은 디렉토리 내용을 읽는 데 사용됩니다. 성능이 좋지 않은 경우 다음과 같은 최적화 전략을 시도해보십시오. 디렉토리 파일 수를 단순화하십시오. 대규모 디렉토리를 가능한 한 여러 소규모 디렉토리로 나누어 읽기마다 처리 된 항목 수를 줄입니다. 디렉토리 컨텐츠 캐싱 활성화 : 캐시 메커니즘을 구축하고 정기적으로 캐시를 업데이트하거나 디렉토리 컨텐츠가 변경 될 때 캐시를 업데이트하며 readDir로 자주 호출을 줄입니다. 메모리 캐시 (예 : Memcached 또는 Redis) 또는 로컬 캐시 (예 : 파일 또는 데이터베이스)를 고려할 수 있습니다. 효율적인 데이터 구조 채택 : 디렉토리 트래버스를 직접 구현하는 경우 디렉토리 정보를 저장하고 액세스하기 위해보다 효율적인 데이터 구조 (예 : 선형 검색 대신 해시 테이블)를 선택하십시오.

See all articles