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

redis运维(十七)事务

一  redis事务

事务核心参考

①   基础概念

1、场景'引入'核心:通过现象'思考原因'?

2、'事务'的概念

3、事务'四大'特性说明: redis只'具备部分'特性

重点1: '原子性'和'一致性'

重点2: '隔离性'和'持久性'

②   redis的事务

1、'基础'铺垫备注: redis提供了'简单的事务',不支持'事务回滚'

2、redis的'事务'命令核心点:1、在一个'客户端'操作的时候,把'所有的指令'一次性按照'顺序'放在一个'队列'中2、执行完了之后再让'其他的客户端'操作

事务相关的命令

1、multi  -->  '开启事务',标记一个'事务块的开始'备注: 设定事务的'开启 start'位置,此指令执行后,'后续的所有指令'均加入到'事务'中2、exec   -->  '执行事务'作用:设定事务的'结束 end'位置,同时执行事务,与multi '成对'出现,成对使用备注1:若在'事务队列'中存在'命令性'错误,则'执行EXEC'命令时,所有命令'都不会'执行备注2:若在事务队列中存在'语法性'错误,则执行EXEC命令时,其他正确命令会被执行,错误命令抛出异常也即:已经'执行完毕的命令'对应的数据'不会自动回滚',需要程序员'自己在代码中'实现回滚3、discard作用: 终止'当前事务的定义',发生在'multi之后',exec之'前'场景: 你在命令入队列的时候,发现你有些命令指令输入错误,你不想执行了,这个时候,你不想提交事务了

备注:1、mysql的commit是'先执行'了,然后'又回滚'了2、而redis的'discard'是取消redis服务器'暂存队列'的内容,'不执行'QUEUED : '队列'

备注:1、虽然'将命令序列化后'发给redis服务器,但是redis'并没有'执行2、而是放在一个'独立的暂存区域[队列中]'3、只有'客户端'发送'EXEC'的命令,对于redis就是一个信号,redis服务器端'才会执行'.缺点:每次发送命令都会'进行一个I/O操作',在服务器进行'多个命令'打包

③   事务特殊情况

1、'语法 synax'错误

说明: '报错时',所有的命令'都不会'执行,'完全回滚'命令'语法'错误: 一个事务中的'多个命令'都'不会'执行备注: '语法'错误,redis-cli客户端会'进行校验'

2、'类型操作'错误备注: 在'类型'执行时'报错',这时一个事务中的'多个命令','对的会执行','错的不会'执行

说明: redis只有'在服务器端执行'才知道'是否错误'常见: 1、incr email 'email'不是'整数'类型2、number 不是 'list'列表类型

④  事务小结

⑤  事务的工作流程

一个事务'从开始到结束'通常会进过以下'三个'阶段:(1)事务开始 (2)命令入队 (3)事务执行

百度二面:谈谈你对Redis事务的理解

⑥  watch

说明: watch 监控key备注: redis使用watch来提供'乐观锁',类似 'cas(check and set)'

乐观锁

乐观锁version和时间戳外的实现方式

乐观锁的version和timestamp

分布式锁和消息队列

思考: 乐观锁'乐观在哪'?

redis 锁和分布式锁 

1、'不开启'watch监控时,事务中的key被修改'不影响事务'的执行2、'开启'watch监控时,'事务中的key被修改'影响'事务的执行'  --> '案例演示'

结果:1、由于在'redis-cli'中的 'key k1'被'watch'监控2、另一个redis客户端'修改k1后',再'执行事务'修改k1,则整个事务中的所有命令'都不会'执行补充: unwatch '取消监控key'

⑦  并发竞争key

分布式锁和消息队列

核心点: 体会'设计'思路

相关文章:

redis运维(十七)事务

一 redis事务 事务核心参考 ① 基础概念 1、场景引入核心:通过现象思考原因? 2、事务的概念 3、事务四大特性说明: redis只具备部分特性 重点1: 原子性和一致性 重点2: 隔离性和持久性 ② redis的事务 1、基础铺垫备注&…...

Vue框架学习笔记——Vue实例中el和data的两种写法

文章目录 前文提要Vue实例的el第一种写法第二种写法小结 Vue实例中data第一种写法&#xff0c;对象式效果图片第二种写法&#xff0c;函数式效果图片小结 前文提要 本文仅做自己的学习记录&#xff0c;如有错误&#xff0c;请多谅解 Vue实例的el 第一种写法 <body><…...

libbz2 for Mac OS makefile

git地址&#xff1a;git://sourceware.org/git/bzip2.git a文件Makefile # ------------------------------------------------------------------ # This file is part of bzip2/libbzip2, a program and library for # lossless, block-sorting data compression. # # bzip…...

测试工具JMeter的使用

目录 JMeter的安装配置 测试的性能指标 TPS 响应时长 并发连接 和 并发用户 CPU/内存/磁盘/网络 负载 性能测试实战流程 JMeter JMeter快速上手 GUI模式 运行 HTTP请求默认值 录制网站流量 模拟间隔时间 Cookie管理器 消息数据关联 变量 后置处理器 CSV 数据文…...

C++编程——输入

#include<bits/stdc.h> using namespace std; int main(){//beginint a 0, b 0, c 0, d 0, e 0;char f1, f2;char g[30];scanf("%d", &a); //输入整数并赋值给变量ascanf("%d", &b); //输入整数并赋值给变量bscanf("%d", &…...

opencv-直方图

直方图是一种对图像亮度分布的统计表示&#xff0c;它显示了图像中每个灰度级别的像素数量。在OpenCV中&#xff0c;你可以使用cv2.calcHist() 函数计算直方图。 以下是一个简单的示例&#xff0c;演示如何计算和绘制图像的直方图&#xff1a; import cv2 import numpy as np …...

el-table表格排序(需要后端判别),el-table导出功能(向后端发送请求)

&#xff08;1&#xff09;表格排序 &#xff08;2&#xff09;简单的table导出功能&#xff08;需要后台支撑&#xff09;必须要有iframe &#xff08;3&#xff09;页面所有代码&#xff1a; <template><div class"mainContainer"><el-form:model&…...

【MATLAB】全网入门快、免费获取、持续更新的科研绘图教程系列2

14 【MATLAB】科研绘图第十四期表示散点分布的双柱状双Y轴统计图 %% 表示散点分布的双柱状双Y轴统计图%% Made by Lwcah &#xff08;公众号&#xff1a;Lwcah&#xff09; %% 公众号&#xff1a;Lwcah %% 知乎、B站、小红书、抖音同名账号:Lwcah&#xff0c;感谢关注~ %% 更多…...

git与ssh多账户共存

git与ssh多账户共存 前言git多账户ssh多公钥参考 前言 在使用git与ssh时&#xff0c;经常会遇到多个账户共存的情况 例如使用不同的公钥登陆到不同的服务&#xff1b;使用不同的git信息进行commit git多账户 在默认情况下 git的信息存在 ~/.gitconfig 可以使用命令查看 git…...

BLE协议栈入门学习

蓝牙LE栈 物理层 频带 蓝牙LE在2400MHz到2483.5MHz范围内的2.4GHz免授权频段工作&#xff0c;该频段分为40个信道&#xff0c;每个信道间隔为2MHz。 时分 蓝牙LE是半双工的&#xff0c;可以发送和接收&#xff0c;但不能同时发送和接收&#xff0c;然而&#xff0c;所有的设…...

【反射】简述反射的构造方法,成员变量成员方法

&#x1f38a;专栏【JavaSE】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 &#x1f970;欢迎并且感谢大家指出我的问题 文章目录 &#x1f384;什么是反射&#x1f384;获取class对象的三种方式⭐代码实现 &#x1f3…...

acwing算法基础之数学知识--求卡特兰数

目录 1 基础知识2 模板3 工程化 1 基础知识 题目&#xff1a;给定n个0和n个1&#xff0c;它们将按照某种顺序排成长度为2n的序列&#xff0c;求它们能排成的所有序列中&#xff0c;能够满足任意前缀序列中0的个数都不少于1的个数的序列有多少个&#xff1f; 输出的答案对 1 0 …...

《洛谷深入浅出基础篇》P4017最大食物链————拓扑排序

上链接&#xff1a;P4017 最大食物链计数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)https://www.luogu.com.cn/problem/P4017 上题干&#xff1a; 题目背景 你知道食物链吗&#xff1f;Delia 生物考试的时候&#xff0c;数食物链条数的题目全都错了&#xff0c;因为她总是…...

设置定时自动请求测试_自动定时循环发送http_post请求---postman工作笔记001

其实就是创建接口文件夹的时候,有个monitor collection 用来监听接口执行情况,这里就可以设置 可以看到多久执行一次对吧,这里可以设置每几分钟执行一次,一共执行多少次等等 但是这里要说明一下,如果需要使用monitor功能,必须需要登录, 所以如果这里点击monitor collection…...

Vue3封装全局插件

定义一个全局加载组件 一、首先定义dom元素 定义一个index.vue文件 <template><div class"loading">loading...</div> </template> <script setup lang"ts"></script> <style scoped> .loading {display: fl…...

【Python 训练营】N_6 求素数

题目 判断101-200之间有多少个素数&#xff0c;并输出所有素数。 分析 判断素数的方法&#xff1a;用一个数分别去除2到sqrt(这个数)&#xff0c;如果能被整除&#xff0c;则表明此数不是素数&#xff0c;反之是素数。 答案 h 0 leap 1 from math import sqrt from sys …...

【图论】关键路径求法c++

代码结构如下图&#xff1a; 其中topologicalSort(float**, int, int*, bool*, int, int)用来递归求解拓扑排序&#xff0c;topologicalSort(float**, int*&, int, int, int)传参图的邻接矩阵mat与结点个数n&#xff0c;与一个引用变量数组topo&#xff0c;返回一个布尔值…...

基于51单片机电子钟万年历LCD1602显示

51单片机的电子钟万年历LCD1602显示 &#x1f534; &#x1f535;51单片机的电子钟万年历LCD1602显示&#x1f534; &#x1f535;主要功能&#xff1a;&#x1f534; &#x1f535;讲解视频&#x1f534; &#x1f535;仿真图&#xff1a;&#x1f534; &#x1f535;程序&…...

时间复杂度和运算

时间复杂度 在算法和数据结构中&#xff0c;有许多时间复杂度比 O(1) 更差的情况。以下是一些常见的时间复杂度&#xff0c;按照从最优到最差的顺序排列&#xff1a; O(1)&#xff1a; 常数时间复杂度&#xff0c;操作的运行时间与输入规模无关&#xff0c;是最理想的情况。 O…...

深入Tailwind CSS中的文本样式

深入Tailwind CSS中的文本样式 样式文本是网页设计的一个基本组成部分&#xff0c;而 Tailwind CSS 提供了范围广泛的实用类&#xff0c;使文本样式设计既高效又有效。 在本本中&#xff0c;我们将探索文本样式的常见最佳实践,讨论潜在的陷阱&#xff0c;并推荐设计方法。我们…...

科哥SenseVoice Small镜像:一键部署语音情感识别AI应用

科哥SenseVoice Small镜像&#xff1a;一键部署语音情感识别AI应用 1. 语音情感识别技术概述 1.1 技术背景与发展 语音情感识别技术正在从实验室走向实际应用场景。传统语音识别系统只能回答"说了什么"&#xff0c;而现代多模态音频理解模型则能同时回答"以什…...

从“选择面”到“选择任何东西”:一个C# NXOpen SelectionType数组的万能配置指南

从“选择面”到“选择任何东西”&#xff1a;一个C# NXOpen SelectionType数组的万能配置指南 在NXOpen二次开发中&#xff0c;对象选择是最基础却又最关键的交互环节。传统做法往往为每种对象类型单独编写选择逻辑——选择面、边、体各有一套代码&#xff0c;这不仅造成代码冗…...

3步打造超逼真终端模拟器:daisyUI极简实现指南

3步打造超逼真终端模拟器&#xff1a;daisyUI极简实现指南 【免费下载链接】daisyui &#x1f33c; &#x1f33c; &#x1f33c; &#x1f33c; &#x1f33c;  The most popular, free and open-source Tailwind CSS component library 项目地址: https://gitcode.com/Git…...

Vue3 + Element-UI项目里,手把手教你搞定TinyMCE 6本地化部署(告别API-Key和云服务报错)

Vue3 Element-UI项目实战&#xff1a;TinyMCE 6完整本地化集成指南 在后台管理系统开发中&#xff0c;富文本编辑器是不可或缺的核心组件。当Vue3遇上Element-UI&#xff0c;再结合TinyMCE 6的强大编辑能力&#xff0c;本应成就完美的技术组合。但现实往往充满挑战——云服务依…...

边缘设备内存告急?Docker 27资源回收黄金配置清单(含ARM64专用cgroup.memory.low阈值公式)

第一章&#xff1a;边缘设备内存告急的底层根源与Docker 27演进关键点边缘计算场景中&#xff0c;内存资源受限是常态而非例外。ARM64架构的工业网关、树莓派集群或车载ECU等典型边缘设备&#xff0c;普遍配备512MB–2GB物理内存&#xff0c;且需同时承载实时操作系统、传感器驱…...

如何部署Hermes Agent/OpenClaw?2026年阿里云及Coding Plan配置详细流程

如何部署Hermes Agent/OpenClaw&#xff1f;2026年阿里云及Coding Plan配置详细流程。OpenClaw&#xff08;前身为Clawdbot/Moltbot&#xff09;作为开源、本地优先的AI助理框架&#xff0c;凭借724小时在线响应、多任务自动化执行、跨平台协同等核心能力&#xff0c;成为个人办…...

SchoolCMS:开源教务管理系统的技术架构创新与实践价值

SchoolCMS&#xff1a;开源教务管理系统的技术架构创新与实践价值 【免费下载链接】schoolcms 中国首个开源学校教务管理系统、网站布局自动化、学生/成绩/教师、成绩查询 项目地址: https://gitcode.com/gh_mirrors/sc/schoolcms SchoolCMS作为中国首个开源的学校教务管…...

告别Linux依赖:在Windows下实现watch式系统监控的三种实用方案

1. Windows用户为何需要watch式监控工具 如果你是从Linux转向Windows的开发者&#xff0c;一定对watch命令不陌生。这个简单实用的小工具可以周期性地执行指定命令并刷新显示结果&#xff0c;特别适合监控系统状态变化。我在日常工作中就经常用它来观察GPU使用率、CPU负载和磁盘…...

Java面试宝典(整理版)附答案详解,一套拿下offer!

对于许多程序员来说&#xff0c;进入大型科技公司&#xff08;如阿里巴巴、腾讯、京东、科大讯飞等&#xff09;是职业发展的重要目标。然而&#xff0c;这些公司的招聘门槛通常较高。为此&#xff0c;我精心整理了一套专门针对这些大厂的面试备考资料。 这套资料全面覆盖了核…...

2026年T3出行赴港IPO,AI+出行模式助力成中国第三大智慧出行平台

2026年4月22日&#xff0c;T3出行正式向港交所递交招股说明书。截至2025年底&#xff0c;它在中国194座城市开展业务&#xff0c;服务超2.345亿用户&#xff0c;2025年订单量居中国第三。发展历程与现状2019年7月T3平台上线&#xff0c;截至2025年12月31日&#xff0c;在中国19…...