当前位置: 首页 > news >正文

4.Redis事务

4.Redis事务


文章目录

    • 4.Redis事务
          • 是什么?
          • 能干嘛?
          • Redis 事务 VS 数据库事务
          • 命令
          • 总结

是什么?

可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞

能干嘛?

在一个队列中,一次性、顺序性、排他性地执行一系列命令。

Redis 事务 VS 数据库事务
单独的隔离操作Redis的事务仅仅是保证事务里的操作会被连续独占的执行,Redis命令执行时单线程架构,在执行完事务内所有指令前是不可能再去同时执行其他客户端的请求的。
没有隔离级别的概念因为事务提交前任何指令都不会被实际执行,也就不存在“事务内的查询要看到事务里的更新,在事务外查询不能看到”这种问题了
不保证原子性Redis的事务不保证原子性,也就是不保证所有指令同时成功或同时失败,只有决定是否开始执行全部指令的能力,没有执行到一半进行回滚的能力。
排他性Redis会保证一个事务内的命令依次执行,而不会被其他命令插入。
命令

开始事务:multi开始一个事务

入队命令:将多个命令放入队到事务中,接到这些命令并不会马上执行,而是放到等待执行的事务队列中

执行事务:exec命令触发事务

watch key1 key2 … : 监视一个或多个key,如果在事务执行之前,被监视的key被其他命令改动,则事务被打断 (乐观锁 )

multi:标记一个事务块的开始

exec:执行所有事务块的命令 ( 一旦执行exec后,之前加的监控锁都会被取消掉 )

discard : 取消事务,放弃事务块中的所有命令

unwatch :取消watch对所有key的监控

127.0.0.1:6379> MULTI
OK
127.0.0.1:6379(TX)> set k1 v1
QUEUED
127.0.0.1:6379(TX)> set k2 v2
QUEUED
127.0.0.1:6379(TX)> set k3 v3
QUEUED
127.0.0.1:6379(TX)> INCR count
QUEUED
127.0.0.1:6379(TX)> EXEC
1) OK
2) OK
3) OK
4) (integer) 2
127.0.0.1:6379> get k3
"v3"
总结

一旦执行力exec,之前加的监控锁都会被取消。

当客户端连接丢失的时候(例如:退出连接),所有的东西都会被取消监视。

http://www.lryc.cn/news/269765.html

相关文章:

  • golang 图片加水印
  • sudo: /usr/bin/sudo must be owned by uid 0 and have the setuid bit set问题解决方案
  • 提升效率:使用注解实现精简而高效的Spring开发
  • 全面好用的setting.xml配置
  • 八股文打卡day14——计算机网络(14)
  • NCNN环境部署及yolov5pt转ncnn模型转换推理
  • selenium模块有哪些用途?
  • 精品Nodejs实现的校园疫情防控管理系统的设计与实现健康打卡
  • 爬虫工作量由小到大的思维转变---<第三十五章 Scrapy 的scrapyd+Gerapy 部署爬虫项目>
  • python测试工具: 实现数据源自动核对
  • 要学习openfoam,c++需要掌握到什么程度?
  • web一些实验代码——Servlet请求与响应
  • GPT系列概述
  • 基于遗传算法的集装箱吊装优化,基于遗传算法的集装箱装卸优化
  • postgreSQL单机部署
  • 思维逻辑题3
  • 强大的音乐乐谱控件库
  • 数据库——简单查询复杂查询
  • java虚拟机内存管理
  • Hive实战:词频统计
  • FairyGUI-Cocos Creator官方Demo源码解读
  • LabVIEW利用视觉引导机开发器人精准抓取
  • 【Linux】指令(本人使用比较少的)——笔记(持续更新)
  • 032 - STM32学习笔记 - TIM基本定时器(一) - 定时器基本知识
  • 轮廓检测与处理
  • 跟着LearnOpenGL学习11--材质
  • Java guava partition方法拆分集合自定义集合拆分方法
  • GLTF编辑器-位移贴图实现破碎的路面
  • 多维时序 | MATLAB实现SSA-BiLSTM麻雀算法优化双向长短期记忆神经网络多变量时间序列预测
  • docker安装Nacos和Rabbitmq