Redis附加功能-事务

120 阅读1分钟
介绍
  • 允许用户将多个命令包裹起来,然后一次性地按顺序地执行被包裹的所有命令
  • 事务执行的过程中,服务器不会中断事务而改去执行其他命令请求,只有在事务的所有命令都被执行完毕之后,服务器才会去处理其他命令请求
  • 一次性地执行多个命令, 并且确保事务中的命令要么就全部都执行,要么就一个都不执行
事务命令
  • 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)
    
流水线与事务的区别
功能性能
流水线确保多条命令会被一起发送
事务确保多条命令会被一起执行