Redis自学笔记:4.1进阶-事务
第4章:进阶
4.1事务
4.1.1概述
redis中的事务是一组命令的集合
事务同命令一样都是redis的最小执行单位,一个事务中的命令要么都执行,
要么都不执行
事务的原理是先将一个事务的命令发送给redis,然后再让redis依次执行
这些命令,例如:
127.0.0.1:6379> multi
OK
127.0.0.1:6379> sadd 'user:1:following' 2
QUEUED
127.0.0.1:6379> sadd 'user:2:following' 1
QUEUED
127.0.0.1:6379> exec
1
1
事务的使用方式:
- 首先使用 multi 命令,声明下面的命令属于同一个事务
- 发送操作命令.redis不会执行命令,而是把它们暂存起来.
返回值 queued 表示这两条命令已进入等待执行事务的队列. - 最后使用 exec 命令结束暂存命令,同时redis将事务队列中的
所有命令按照发送顺序依次执行. exec 返回值是暂存命令执
行的返回值组成的列表,返回顺序和命令顺序相同.
redis保证一个事务中的所有命令要么都执行,要么都不执行.如果在发
送exec命令前客户端断线,redis会清空事务队列.一旦发送了redis命令,
所有命令就会被执行,即使客户端断线也没有关系.
redis的事务还能保证一个事务内的命令依次执行而不被其他命令插入.
4.1.2错误处理
导致事务执行出错的原因:
- 语法错误.
命令不存在或者命令参数的个数不对.127.0.0.1:6379> multi
OK
127.0.0.1:6379> set foo 1
QUEUED
127.0.0.1:6379> set foo
ERR wrong number of arguments for 'set' command
127.0.0.1:6379> errorcommand foo
ERR unknown command 'errorcommand'
127.0.0.1:6379> exec
EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> keys *
- 事务中的命令都没有执行
- 运行错误
命令执行时出现的错误.比如使用散列类型的命令操作集合类型的键,这
种错误在实际执行之前redis是无法发现的.如果事务里一条命令出现了
运行错误,事务里其他的命令依然会执行(包括出错命令之后的命令).127.0.0.1:6379> multi
OK
127.0.0.1:6379> set foo 1
QUEUED
127.0.0.1:6379> sadd foo 2
QUEUED
127.0.0.1:6379> set foo 3
QUEUED
127.0.0.1:6379> exec
OK
WRONGTYPE Operation against a key holding the wrong kind of value
OK
127.0.0.1:6379> keys *
foo
127.0.0.1:6379> get foo
3
redis的事务没有关系数据库提供的回滚(rollback)功能.也使得redis在事务
上可以保持简洁和快速.
4.1.3 watch命令介绍
watch命令可以监控一个或多个键,一旦其中有一个键被修改(或删除),之后的
事务就不会执行。监控一直持续到exec命令(事务中的命令是在exec之后才执行
的,所以在multi命令后可以修改watch监控的键值)
127.0.0.1:6379> set qux 1
OK
127.0.0.1:6379> watch qux
OK
127.0.0.1:6379> set qux 2
OK
127.0.0.1:6379> get qux
2
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set qux 3
QUEUED
127.0.0.1:6379> exec
127.0.0.1:6379> get qux
2
127.0.0.1:6379> set thud 1
OK
127.0.0.1:6379> watch thud
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set thud 2
QUEUED
127.0.0.1:6379> exec
OK
127.0.0.1:6379> get thud
2
由于watch命令的作用只是当被监控的键值被修改后阻止之后一个事务的执行,而
不能保证其他客户端不修改这一键值,所以在一般的情况下我们需要在exec执行失
败后重新执行整个函数。
执行exec命令后会取消对所有键的监控,如果不想执行事务中的命令也可以使用
unwatch命令来取消监控。
Redis自学笔记:4.1进阶-事务的更多相关文章
- Redis自学笔记:4.4进阶-消息通知
4.4消息通知 4.4.1任务队列 传递任务的队列.与任务队列进行交互的实体有两类,一类是生产者,一类是消费者. 生产者将需要处理的任务放入任务队列中,二消费者不断从任务队列中读入任务 信息并执行. ...
- Redis自学笔记:4.3进阶-排序
4.3排序 4.3.1有序集合的集合操作 有序集合没有zinter和zunion命令,使用其他命令实现方法: multi zinterstore tempKey ... zrange tempKey ...
- Redis自学笔记:4.2进阶-过期时间
4.2过期时间 **4.2.1命令介绍* 在redis中使用 expire 命令设置一个键的过期时间后redis会自动删除它. expire key seconds (seconds单位是秒,必须是整 ...
- redis 学习笔记——数据同步、事务
redis主从同步 redis支持简单易用的主从复制(master-slave replication)功能,该功能也是redis高可用性实现的基础. redis复制原理 re ...
- Redis自学笔记:5.实践
第5章实践 5.3 python与redis 5.3.1安装 pip install redis 5.3.2使用方法 自己补充内容:Ubuntu下redis开启远程连接 打开redis配置:sudo ...
- Redis自学笔记:3.6入门-有序集合类型
3.6有序集合类型 3.6.1介绍 在集合类型基础上,为集合中每个元素都关联了一个分数,故可以获得 分数最高(最低)的前N个元素,可以获得指定范围内的元素等 有序集合中每个元素不同,但它们的分数却可以 ...
- Redis自学笔记:3.5入门-集合类型
3.5集合类型 3.5.1介绍 在集合中的每个元素都是不同的,且没有顺序 表3-4集合类型和列表类型的对比 - 集合类型 列表类型 存储内容 至多232-1个字符串 至多232-1个字符串 有序性 否 ...
- Redis自学笔记:3.4入门-列表类型
3.4列表类型 3.4.1介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者 获得列表的某一片段. 优点:内部使用的是双向链表,所以向列表两端添加元素的时间复杂度为O(1 ...
- Redis自学笔记:3.3入门-散列类型
3.3散列类型 3.3.1介绍 散列类型不能嵌套其他数据类型,一个散列类型可以包含至多232-1个字段 散列类型适合存储对象:使用对象类别和ID构成键名,使用字段表示对象的数据, 而字段值则存储属性值 ...
随机推荐
- poj3070 单位矩阵(转移矩阵构造)+矩阵快速幂
太妙了..通过矩阵乘法来加速递推 #include<iostream> #include<cstring> #include<cstdio> using names ...
- 怎样在win7 IIS中部署网站
怎样在win7 IIS中部署网站? IIS作为微软web服务器的平台,可以轻松的部署网站,让网站轻而易举的搭建成功,那么如何在IIS中部署一个网站呢,下面就跟小编一起学习一下吧. 第一步:发布IIS文 ...
- inline namespace
无意中看到C++11中的新特性inline namespace, 先附上官方的解释 Inline namespace The inline namespace mechanism is intende ...
- mysql的时间戳timestamp精确到小数点后六位
1.mysql的时间戳timestamp精确到小数点后六位. 公司业务使用到Greenplun数据库,根据查询的时间戳来不断的将每个时间段之间的数据,进行数据交换,但是今天发现,mysql的时间戳没有 ...
- exception: java.net.ConnectException: Connection refused; For more details see: http://wiki.apache.org/hadoop/ConnectionRefused
1.虽然,不是大错,还说要贴一下,由于我运行run-example streaming.NetworkWordCount localhost 9999的测试案例,出现的错误,第一感觉就是Spark没有 ...
- 各厂商服务器存储默认管理口登录信息(默认IP、用户名、密码)收集
666:https://blog.csdn.net/xiezuoyong/article/details/84997917
- Java集合源码学习(四)HashMap
一.数组.链表和哈希表结构 数据结构中有数组和链表来实现对数据的存储,这两者有不同的应用场景,数组的特点是:寻址容易,插入和删除困难:链表的特点是:寻址困难,插入和删除容易:哈希表的实现结合了这两点, ...
- 3.ELK 之elasticsearch CRUD
名词介绍 index: type: document: 数据类型: 索引(index)创建示例 . type的创建(7.x之后)将会去掉该内容,点我看为什么? 参考脚本: mapping使用 其他 ...
- 分布式系统的CAP理论
一.CAP理论概述 一个分布式系统最多只能同时满足一致性(Consistency).可用性(Availability)和分区容错性(Partition tolerance)这三项中的两项. 二.CAP ...
- 详细的ifcfg-eth0配置详解
通过查资料与工作中的进行一下总结: DEVICE="eth1" 网卡名称NM_CONTROLLED="yes" network mamager的参数 ,是否 ...