第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

事务的使用方式:

  1. 首先使用 multi 命令,声明下面的命令属于同一个事务
  2. 发送操作命令.redis不会执行命令,而是把它们暂存起来.

    返回值 queued 表示这两条命令已进入等待执行事务的队列.
  3. 最后使用 exec 命令结束暂存命令,同时redis将事务队列中的

    所有命令按照发送顺序依次执行. exec 返回值是暂存命令执

    行的返回值组成的列表,返回顺序和命令顺序相同.

redis保证一个事务中的所有命令要么都执行,要么都不执行.如果在发

送exec命令前客户端断线,redis会清空事务队列.一旦发送了redis命令,

所有命令就会被执行,即使客户端断线也没有关系.

redis的事务还能保证一个事务内的命令依次执行而不被其他命令插入.

4.1.2错误处理

导致事务执行出错的原因:

  1. 语法错误.

    命令不存在或者命令参数的个数不对.
    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 *
    • 事务中的命令都没有执行
  2. 运行错误

    命令执行时出现的错误.比如使用散列类型的命令操作集合类型的键,这

    种错误在实际执行之前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进阶-事务的更多相关文章

  1. Redis自学笔记:4.4进阶-消息通知

    4.4消息通知 4.4.1任务队列 传递任务的队列.与任务队列进行交互的实体有两类,一类是生产者,一类是消费者. 生产者将需要处理的任务放入任务队列中,二消费者不断从任务队列中读入任务 信息并执行. ...

  2. Redis自学笔记:4.3进阶-排序

    4.3排序 4.3.1有序集合的集合操作 有序集合没有zinter和zunion命令,使用其他命令实现方法: multi zinterstore tempKey ... zrange tempKey ...

  3. Redis自学笔记:4.2进阶-过期时间

    4.2过期时间 **4.2.1命令介绍* 在redis中使用 expire 命令设置一个键的过期时间后redis会自动删除它. expire key seconds (seconds单位是秒,必须是整 ...

  4. redis 学习笔记——数据同步、事务

    redis主从同步      redis支持简单易用的主从复制(master-slave replication)功能,该功能也是redis高可用性实现的基础.   redis复制原理      re ...

  5. Redis自学笔记:5.实践

    第5章实践 5.3 python与redis 5.3.1安装 pip install redis 5.3.2使用方法 自己补充内容:Ubuntu下redis开启远程连接 打开redis配置:sudo ...

  6. Redis自学笔记:3.6入门-有序集合类型

    3.6有序集合类型 3.6.1介绍 在集合类型基础上,为集合中每个元素都关联了一个分数,故可以获得 分数最高(最低)的前N个元素,可以获得指定范围内的元素等 有序集合中每个元素不同,但它们的分数却可以 ...

  7. Redis自学笔记:3.5入门-集合类型

    3.5集合类型 3.5.1介绍 在集合中的每个元素都是不同的,且没有顺序 表3-4集合类型和列表类型的对比 - 集合类型 列表类型 存储内容 至多232-1个字符串 至多232-1个字符串 有序性 否 ...

  8. Redis自学笔记:3.4入门-列表类型

    3.4列表类型 3.4.1介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者 获得列表的某一片段. 优点:内部使用的是双向链表,所以向列表两端添加元素的时间复杂度为O(1 ...

  9. Redis自学笔记:3.3入门-散列类型

    3.3散列类型 3.3.1介绍 散列类型不能嵌套其他数据类型,一个散列类型可以包含至多232-1个字段 散列类型适合存储对象:使用对象类别和ID构成键名,使用字段表示对象的数据, 而字段值则存储属性值 ...

随机推荐

  1. 《剑指offer》 合并两个排序的链表

    本题来自<剑指offer> 合并两个排序的链表 题目: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路: A:采用递归的方式(C++ C ...

  2. tomcat 报错处理

    一.tomcat报错找不到资源集市 原因:tomcat的配置文件sever.xml 里的 docbase配置被Eclispe修改了 解决方法:修改回来 <Context docBase=&quo ...

  3. 4.8cf自训

    发现cf以前的好题真的很多.. cf 730j 01背包变形 感觉很好的题 /* 先处理出最少需要t个瓶子 dp[i][j][k]前i个取k个,容量为j时的水的体积 滚动数组搞一下 本题的状态转移必须 ...

  4. Appium 常用方法总结 (python 版)

    1.app后台运行 driver.background_app(5) 2.锁屏 driver.lock(5) 3.隐藏键盘 driver.hide_keyboard() 4.启动一个app或者在当前a ...

  5. CentOS安装jdk的三种方法

    方法一:手动解压JDK的压缩包,然后设置环境变量 方法二:用yum安装JDK,(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的 ...

  6. Python-数据类型之数字

    一:数字类型概述 数字提供了标量存储和直接访问,属于不可变数据类型,所谓不可变,我们可以认为,更改数字的值会生成一个新的对象 # id可以唯一表示一个对象 age =18 print(id(age)) ...

  7. Spring.Net 简单实例-02(属性注入)

    说明:接续Spring.Net 简单实例-01(IOC) 话不多说看操作 1:为UserInfo添加属性 2: 修改App.config中代码 <?xml version="1.0&q ...

  8. B: Ocean的游戏(前缀和)

    B: Ocean的游戏 Time Limit: 1 s      Memory Limit: 128 MB Submit My Status Problem Description 给定一个字符串s, ...

  9. openmp查看最大线程数量

    CMakeLists.txt cmake_minimum_required(VERSION 2.8) project(omp_test) find_package(OpenMP REQUIRED) i ...

  10. 微信jssdk分享功能开发

    先理解下分享: 在app端 ,经常能看见 分享按钮的功能,(分享给朋友,分享到朋友圈,分享到QQ空间等等): https://open.weixin.qq.com/(微信开发平台),这需要到开放平台注 ...