Redis事务
2014-12-22 11:40
239 查看
事务
事务概念
redis中的事务是一组命令的集合。一个事务中的命令要么都执行,要么都不执行。redis> MULTI OK redis> CMD1 QUEUED redis> CMD2 QUEUED ... redis> EXEC 1) (integer) 1 2) (integer) 1
如果在发送EXEC之前,客户端断线了,那么redis会清空事务队列,事务中的所有命令都不会执行。而一旦客户端发送了EXEC命令,所有的命令都会被执行,即使此后客户端断线也没关系,因为redis中已经记录了所有要执行的命令。
除此之外,Redis的事务是一个原子操作, 可以保证一个事务内的命令依次执行而不被其他命令插入
错误处理
语法错误。语法错误指命令不存在或者命令参数的个数不对redis>MULTI OK redis>SET key value QUEUED redis>SET key (error)ERR wrong number of arguments for 'set' command redis> ERRORCOMMAND key (error) ERR unknown command 'ERRORCOMMAND' redis> EXEC (error) EXECABORT Transaction discarded because of previous errors.
只要有一个命令有语法错误,执行EXEC命令后Redis就会直接返回错误,连语法正确的命令也不会执行
注意:Redis 2.6.5之前的版本会忽略有语法错误的命令,然后执行事务中其他语法正确的命令。就此例而言,SET key value会被执行,EXEC命令会返回一个结果:1) OK。
运行错误。运行错误指在命令执行时出现的错误,比如使用散列类型的命令操作集合类型的键,这种错误在实际执行之前Redis是无法发现的,所以在事务里这样的命令是会被Redis接受并执行的。如果事务里的一条命令出现了运行错误,事务里其他的命令依然会继续执行(包括出错命令之后的命令)
redis>MULTI OK redis>SET key 1 QUEUED redis>SADD key 2 QUEUED redis>SET key 3 QUEUED redis>EXEC 1) OK 2) (error) ERR Operation against a key holding the wrong kind of value 3) OK redis>GET key "3"
redis的事务没有关系数据库提供的回滚功能。
watch命令
WATCH命令可以监控一个或多个键,一旦其中有一个键被修改(或删除),之后的事务就不会执行。监控一直持续到EXEC命令(事务中的命令是在EXEC之后才执行的,所以在MULTI命令后可以修改WATCH监控的键值)redis>SET key 1 OK redis>WATCH key OK redis>SET key 2 OK redis>MULTI OK redis>SET key 3 QUEUED redis>EXEC (nil) redis>GET key "2"
上例中在执行WATCH命令后、事务执行前修改了key的值(即SET key 2),所以最后事务中的命令SET key 3没有执行,EXEC命令返回空结果。
由于WATCH命令的作用只是当被监控的键值被修改后阻止之后一个事务的执行,而不能保证其他客户端不修改这一键值,所以我们需要在EXEC执行失败后重新执行整个函数
执行EXEC命令后会取消对所有键的监控,如果不想执行事务中的命令也可以使用UNWATCH命令来取消监控
注意:
如果使用WATCH命令监测了一个拥有生存时间的键,该键时间到期自动删除并不会被WATCH命令认为该键被改变。
如果发现错误,请轻拍,欢迎留言交流,谢谢
相关文章推荐
- Redis--事务
- Nosql数据库——redis(六)事务和持久化
- Redis教程(八):事务详解
- Redis 事务
- Redis的事务功能详解
- Redis的事务
- redis中的事务、lua脚本和管道的使用场景
- Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式…)介绍
- redis事务功能详解
- ServiceStack.Redis常用操作 - 事务、并发锁
- Redis事务(Transaction)
- Redis事务 示例
- Sping Data Redis 使用事务时,不关闭连接的问题
- redis中事务(Transaction)的使用
- Redis---事务
- ServiceStack.Redis常用操作 - 事务、并发锁
- Redis 基础教程之事务的使用方法
- Redis 小白指南(三)- 事务、过期、消息通知、管道和优化内存空间
- Redis-事务
- Redis命令学习-Transaction(事务)