Redis 事务
Redis 事务
事务是一个很重要的数据库
Redis 事务可以一次执行多个命令, 并且带有以下两个重要的特征:
- 事务是一个单独的隔离操作:事务中的所有命令都会按照顺序执行。事务在执行的过程中,不会被其他客户端发送的命令所打断。
- 事务是一个原子性的操作:事务中的命令要么全部被执行,要么全部都不执行。
一个事务从开始到执行会依次经历以下三个阶段:
- 开始事务
- 命令入队
- 执行事务
Redis 事务的常用命令
- DISCARD 取消事务,放弃执行事务块内的所有命令。
- EXEC 执行所有事务块内的命令。
- MULTI 标记一个事务块的开始。
- UNWATCH 取消 WATCH 命令对所有 key 的监视。
- ATCH key [key …] 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
简单的事务控制
以下是一个事务的例子, 它先以 MULTI 命令开始一个事务, 然后将多个命令入队到事务中, 最后由 EXEC 命令触发事务, 一并执行事务中的所有命令:
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET book-name "Mastering C++ in 21 days"
QUEUED
redis 127.0.0.1:6379> GET book-name
QUEUED
redis 127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series"
QUEUED
redis 127.0.0.1:6379> SMEMBERS tag
QUEUED
redis 127.0.0.1:6379> EXEC
1) OK
2) "Mastering C++ in 21 days"
3) (integer) 3
4) 1) "Mastering Series"
2) "C++"
3) "Programming"
取消一个事务
我们可以执行 DISCARD 命令来取消一个事务,让事务回滚。示例如下:
redis 127.0.0.1:6379> SET age 20
OK
redis 127.0.0.1:6379> GET age
"20"
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET age 21
QUEUED
redis 127.0.0.1:6379> SET age 22
QUEUED
redis 127.0.0.1:6379> DISCARD
OK
redis 127.0.0.1:6379> GET age
"20"
该文章会更新,欢迎大家批评指正。
推荐一个零声学院免费公开课程,个人觉得老师讲得不错,
分享给大家:[Linux,Nginx,ZeroMQ,MySQL,Redis,
fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,
TCP/IP,协程,DPDK等技术内容,点击立即学习:
服务器课程:C++服务器