全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
redis事务学习 redis对事务的支持目前还比较简单。redis只能保证一个client发起的事务中的命令可以连续的执行,而中间不会插入其他client的命令。 由于redis是单线程来处理所有client的请求的所以做到这点是很容易的。一般情况下redis在接受到一个client发来的命令后会立即处理并 返回处理结果,但是当一个client在一个连接中发出multi命令有,这个连接会进入一个事务上下文,该连接后续的命令并不是立即执行,而是先放到一 个队列中。当从此连接受到exec命令后,redis会顺序的执行队列中的所有命令。并将所有命令的运行结果打包到一起返回给client.然后此连接就 结束事务上下文。下面可以看一个例子123456789redis multiOKredis incr aQUEUEDredis incr bQUEUEDredis exec1. (integer) 12. (integer) 1从这个例子我们可以看到incr a ,incr b命令发出后并没执行而是被放到了队列中。调用exec后俩个命令被连续的执行,最后返回的是两条命令执行后的结果我们可以调用discard命令来取消一个事务。接着上面例子123456789101112redis multiOKredis incr aQUEUEDredis incr bQUEUEDredis discardOKredis get a1redis get b1可以发现这次incr a incr b都没被执行。discard命令其实就是清空事务的命令队列并退出事务上下文。虽说redis事务在本质上也相当于序列化隔离级别的了。但是由于事务上下文的命令只排队并不立即执行,所以事务中的写操作不能依赖事务中的读操作结果。看下面例子123456789redis multi OKredis get aQUEUEDredis get bQUEUEDredis exec1. 12. 1发现问题了吧。假如我们想用事务实现incr操作怎么办?可以这样做吗?12345678910redis get a1redis multiOKredis set a 2QUEUEDredis exec1. OKredis get a,2结论很明显这样是不行的。这样和 get a 然后直接set a是没区别的。很明显由于get a 和set a并不能保证两个命令是连续执行的(get操作不在事务上下文中)。很可能有两个client同时做这个操作。结果我们期望是加两次a从原来的1变成3. 但是很有可能两个client的get a,取到都是1,造成最终加两次结果却是2。主要问题我们没有对共享资源a的访问进行任何的同步也就是说redis没提供任何的加锁机制来同步对a的访问。还好redis 2.1后添加了watch命令,可以用来实现乐观锁。看个正确实现incr命令的例子,只是在前面加了watch a123456789101112redis watch aOKredis get a1redis multiOKredis set a 2QUEUEDredis exec1. OKredis get a,2watch 命令会监视给定的key,当exec时候如果监视的key从调用watch后发生过变化,则整个事务会失败。也可以调用watch多次监视多个key.这 样就可以对指定的key加乐观锁了。注意watch的key是对整个连接有效的,事务也一样。如果连接断开,监视和事务都会被自动清除。当然了 exec,discard,unwatch命令都会清除连接中的所有监视.redis的事务实现是如此简单,当然会存在一些问题。第一个问题是redis只能保证事务的每个命令连续执行,但是如果事务中的一个命令失败了,并不回滚其他命令,比如使用的命令类型不匹配。123456789101112131415161718redis set a 5OKredis lpush b 5(integer) 1redis set c 5OKredis multiOKredis incr aQUEUEDredis incr bQUEUEDredis incr cQUEUEDredis exec1. (integer) 62. (error) ERR Operation against a key holding the wrong kind of value3. (integer) 6可以看到虽然incr b失败了,但是其他两个命令还是执行了。最 后一个十分罕见的问题是 当事务的执行过程中,如果redis意外的挂了。很遗憾只有部分命令执行了,后面的也就被丢弃了。当然如果我们使用的append-only file方式持久化,redis会用单个write操作写入整个事务内容。即是是这种方式还是有可
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 民间借贷合同范本及法律风险解析
- 公交车辆运营安全管理规范
- 小学数学基础知识强化训练题
- 职业培训课程开发与效果评估方法
- 小学三年级数学期中试题合集
- 儿童游乐场项目投资可行性研究
- 信用修复培训咨询服务方案(3篇)
- 亲子教育咨询方案多少钱(3篇)
- 法律咨询服务方案范文(3篇)
- 制造业咨询方案范文大全(3篇)
- 冷库项目建设全流程风险管理探究:理论、实践与创新策略
- 学前教育应聘
- 智能家具创投项目计划书
- 2024年河南省襄城县人民医院公开招聘医务工作人员试题带答案详解
- 2025年公共基础知识综合考试练习题及解析答案
- 5工程审计管理制度
- 购买轮挖合同协议书
- 船舶碰撞协议书
- 货运部转让合同协议书
- 信息安全应急演练报告
- ZS银行资产托管业务对盈利模式的重塑与影响探究
评论
0/150
提交评论