经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Redis » 查看文章
Redis 事务
来源:cnblogs  作者:chenhongyong  时间:2019/6/26 9:11:03  对本文有异议

Redis 事务可以一次执行多个命令。

 

常用命令:

  • multi     //开起一个事务,标记一个事务块的开始,multi即multiple
  • exec    //执行事务块内的命令
  • discard   //取消事务

 

使用步骤:

  • 先使用 multi命令  标记事务开始
  • 将多个命令入队(queue,队列)
  • 使用 exec 命令执行事务

 

示例:

 multi    //标记事务开始

 set name "zhangsan"    //依次输入多个命令。输入一条命令后会提示“QUEUED”,表示此条命令已入队

 set age 20 

 get name 

 exec    //执行事务,会依次执行事务块内的命令,依次显示执行结果。

exec是执行事务,如果想取消事务,将exec换为discard即可。

 

 

 

 

 

 

 

单个 Redis 命令的执行是原子性的,但 Redis 并没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行不是原子性的。

 

事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。

比如执行事务时,第一条执行成功,第二条执行失败,此时并不会回滚之前的操作(此处指第一条、第二条命令),而是继续执行后面的命令。但会显示第二条的结果是Fail。

即事务中任意命令执行失败,其余的命令依然被执行。

 

在事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令队列中。

 

 

 

Redis2.6以后的版本,在服务器内置了Lua环境(Lua解释器),可以执行Lua脚本。

 

原文链接:http://www.cnblogs.com/chy18883701161/p/11084920.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号