redis 事务与管道

这篇具有很好参考价值的文章主要介绍了redis 事务与管道。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、事务:

1. 事务概述:

1.1 什么是事务:

指可以一次执行多个命令,本质是一组命令的集合。
一个事务中的所有命令都会序列化,按顺序的串行化执行而不会被其他命令插入,不许加塞
即:一个队列中,一次性、顺序性、排他性的执行一系列命令

1.2 与传统关系型数据库的事务相比redis事务的不同之处:

我觉得最关键的一个不同就是redis事务不能保证原子性,在MySQL的一个事务里的命令要么全部成功要么全部失败,
但是在redis事务里,它只会把这个事务里的一系列命令执行完,不管成功与否,事务都算结束了
redis 事务与管道

2. 事务的常用操作:

2.1 事务正常执行:

输入MULTI命令标记开启一个事务,之后的每条命令都会进入对列,显示QUEUED即已经进入队列。
输入EXEC命令,会执行事务块内(队列)的所有命令。
redis 事务与管道

2.2 放弃事务:

在事务块内输入命令DISCARD,该事务块内的所有命令不会执行,并且退出该事务块。
redis 事务与管道

2.3 事务异常(执行异常):

执行前异常一般是这种命令出错(编译错误)的异常
redis 事务与管道

2.4 事务异常(执行异常):

执行后异常一般指执行错误的异常,这种异常,除了出错的命令外,正常执行的命令都会在这个事务块执行后成功运行。不能保证原子性的原因。
redis 事务与管道

2.5 watch监控:

1)加监控且没有被篡改的情况:
redis 事务与管道

2)加监控出现加塞篡改的情况:
redis 事务与管道

说明:

watch命令是一种乐观锁的实现,Redis在修改的时候会检测数据是否被更改,如果更改了,则执行失败
第一个窗口蓝色框第5步执行结果返回为空,也就是相当于是失败,整个事务的命令都不会成功执行,相当于DISCARD

复习:悲观锁和乐观锁

悲观锁(Pessimistic Lock), 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。
乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。
乐观锁策略:提交版本必须大于记录当前版本才能执行更新
redis是性能优先的数据库,肯定是使用的乐观锁实现,因为悲观锁实现会频繁加锁,对性能的消耗大。

3)unwatch:
开启unwatch后,在该命令之前的监控全部失效,不会对数据进行监控
redis 事务与管道

4)注意:
一旦执行了EXEC,之前加的监控锁都会被取消掉;当客户端连接断开时,所有监控锁会被取消。

二、管道:

1. 管道概述:

1.1 管道出现的背景:

Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。一个请求会遵循以下步骤:
1) 客户端向服务端发送命令分四步(发送命令→命令排队→命令执行→返回结果),并监听Socket返回,通常以阻塞模式等待服务端响应。
2) 服务端处理命令,并将结果返回给客户端。
上述两步称为:Round Trip Time(简称RTT,数据包往返于两端的时间)
redis 事务与管道
如果同时需要执行大量的命令,那么就要等待上一条命令应答后再执行,这中间不仅仅多了RTT(Round Time Trip),而且还频繁调用系统IO,发送网络请求,同时需要redis调用多次read()和write()系统方法,系统方法会将数据从用户态转移到内核态,这样就会对进程上下文有比较大的影响了,性能不太好,o(╥﹏╥)o

1.2 管道的定义:

管道是为了解决命令往返过于频繁而导致的RTT时长过长,仅仅是将命令打包一次性发送,对整个redis的执行不造成其他任何影响。
它属于批处理命令变种优化措施,类似redis的原生批处理命令(mset和mget),但是这种批处理命令(例如mset)只能对string类型的数据批处理
如果需要对多种类型数据批处理,就必须使用管道了
所以,管道的出现能对频繁的命令往返进行优化,从而提升redis的性能

2. 管道实操:

2.1 先清空数据库(方便直观地显示操作结果):

redis 事务与管道

2.2 使用管道进行批处理:

redis 事务与管道
这时候再去查询数据库会发现,这些命令都被成功且正确的执行了
redis 事务与管道
redis 事务与管道

2.3 管道与原生批命令对比:

redis 事务与管道

2.4 管道与事务对比:

redis 事务与管道

2.5 注意:

管道缓冲的指令只是会依次执行,不保证原子性,如果执行过程中指令发生异常,将会继续执行后续的指令。
使用管道组装的命令个数也不能太多,不然数据量过大,客户端阻塞的时间可能过久,同时服务端此时也被迫回复一个队列答复,占用很多内存。文章来源地址https://www.toymoban.com/news/detail-444072.html

到了这里,关于redis 事务与管道的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis(概述、应用场景、线程模式、数据持久化、数据一致、事务、集群、哨兵、key过期策略、缓存穿透、击穿、雪崩)

    目录 Redis概述 应用场景 Redis的线程模式 数据持久化 1.Rdb(Redis DataBase) 2.Aof(Append Only File) mysql与redis保持数据一致 redis事务 主从复制(Redis集群) 哨兵模式 key过期策略 缓存穿透、击穿、雪崩 1.缓存穿透:缓存中没有,在mysql中也没有 2.缓存击穿:数据在数据库中存在,某个

    2024年01月16日
    浏览(64)
  • 2023-06-09:什么是Redis事务?原理是什么?

    2023-06-09:什么是Redis事务?原理是什么? 答案2023-06-09: Redis中的事务是以一组命令的形式出现的,这些命令被认为是最小的执行单位。事务可以保证在一个单独独立的隔离操作中执行所有命令,而且所有命令都会按照指定的顺序经过序列化后被执行。在服务端执行事务的过

    2024年02月08日
    浏览(101)
  • redis事务对比Lua脚本区别是什么

    redis官方对于lua脚本的解释:Redis使用同一个Lua解释器来执行所有命令,同时,Redis保证以一种原子性的方式来执行脚本:当lua脚本在执行的时候,不会有其他脚本和命令同时执行,这种语义类似于 MULTI/EXEC。从别的客户端的视角来看,一个lua脚本要么不可见,要么已经执行完

    2024年02月12日
    浏览(41)
  • Redis 是什么和使用场景概述(技术选型)

         Redis是一款开源的高性能键值存储系统。它支持多种数据结构,如字符串、列表、集合、哈希表、有序集合等,并提供了丰富的操作命令和功能。Redis的主要特点包括: 内存存储:Redis将数据存储在内存中,因此读写速度非常快。同时,Redis还可以将数据持久化到磁盘,

    2024年02月07日
    浏览(31)
  • Redis可以用作数据库吗?它的适用场景是什么?

    是的,Redis可以用作数据库。虽然Redis通常被认为是一个内存数据库(in-memory database),但它也可以通过持久化机制将数据保存在磁盘上,以便在重启后恢复数据。 Redis的适用场景包括但不限于以下几个方面: 缓存:Redis的高性能、低延迟和良好的缓存策略使得它非常适合作为

    2024年02月13日
    浏览(40)
  • 【Redis学习】Redis管道

    问题由来 客户端向服务端发送命令分四步(发送命令→命令排队→命令执行→返回结果),并监听Socket返回,通常以阻塞模式等待服务端响应。 服务端处理命令,并将结果返回给客户端。 上述两步称为:Round Trip Time(简称RTT,数据包往返于两端的时间) 如果同时需要执行大量的命令

    2023年04月09日
    浏览(35)
  • 【redis】redis管道简述

    redis管道可以一次性发送多条命令。 命令示例如下: 下面先简述一下这条命令的组成,再简述一下管道的常用场景和注意事项。 首先,\\\'|\\\'是Linux中的管道符,即管道符之前命令的输出作为管道符之后命令的输入。 再看下管道符之前的命令,echo -e。echo实际上是返回输入字符串

    2024年02月17日
    浏览(37)
  • Redis管道操作

    如何优化频繁命令往返造成的性能瓶颈? Redis是一种基于C/S一级请求响应协议的TCP服务,一个请求会遵循一下步骤: 客户端向服务端发送命令分四步(发送命令- 命令排队- 命令执行- 返回结果),并监听Socket返回,通常以阻塞方式等待服务器响应。 服务端处理命令,并将结

    2024年01月18日
    浏览(45)
  • redis管道代码

    1:如果将redis的key,在redis删除或者过期,返回数据会是null 2:返回的list是所有key的合集 ,如果key不存在,则返回null 3:  存的key和value是否是二进制跟你的配置文件有关,    准备的数据 execute :方法是串行的,命令请求发出后,必须得到响应数据,才能发送下一条命令请求

    2024年02月16日
    浏览(33)
  • Redis管道

    背景 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。一个请求会遵循以下步骤: 1 客户端向服务端发送命令分四步(发送命令→命令排队→命令执行→返回结果),并监听Socket返回,通常以阻塞模式等待服务端响应。 2 服务端处理命令,并将结果返回给客户端。

    2024年02月05日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包