介绍
- 允许用户将多个命令包裹起来,然后一次性地按顺序地执行被包裹的所有命令
- 事务执行的过程中,服务器不会中断事务而改去执行其他命令请求,只有在事务的所有命令都被执行完毕之后,服务器才会去处理其他命令请求
- 一次性地执行多个命令, 并且确保事务中的命令要么就全部都执行,要么就一个都不执行
事务命令
- MULTI
开始一个新的事务
在这个命令执行之后,客户端发送的所有针对数据库或者数据库键的命令都不会被立即执行,而是被放入到一个事务队列里面,并返回 QUEUED 表示命令已入队127.0.0.1:6379> multi OK 127.0.0.1:6379> set msg "hello world" QUEUED 127.0.0.1:6379> expire msg 600 QUEUED
- DISCARD
取消事务,放弃执行事务队列中的所有命令127.0.0.1:6379> discard OK 127.0.0.1:6379> set msg "hello world" OK
- EXEC
执行事务中的所有命令
按照命令被入队到事务队列中的顺序,执行事务队列中的所有命令
命令的返回值是一个列表,列表里包含了事 务队列中所有被执行命令的返回值
事务错误:127.0.0.1:6379> multi OK 127.0.0.1:6379> set msg "hello world" QUEUED 127.0.0.1:6379> expire msg 600 QUEUED 127.0.0.1:6379> exec 1) OK 2) (integer) 1
127.0.0.1:6379> multi OK 127.0.0.1:6379> set msg "hello world" QUEUED 127.0.0.1:6379> expire msg 1x QUEUED 127.0.0.1:6379> exec (error) EXECABORT Transaction discarded because of previous errors. 127.0.0.1:6379> get msg (nil)
流水线与事务的区别
功能 | 性能 |
---|---|
流水线 | 确保多条命令会被一起发送 |
事务 | 确保多条命令会被一起执行 |