redis之如何应对并发访问问题

news2025/1/15 6:33:03

写在前面

本文一起看下Redis的并发访问控制。

1:单线程的Redis为什么会有并发问题

我们知道,Redis是单线程的,为什么还是会有并发问题呢?没错,如果是单命令操作的话肯定没有并发问题,但考虑事务的场景,比如库存量,我们会按照如下的步骤进行修改:

1:读取库存量
2:减少库存量
3:写回库存量

我们把这个流程叫做读取-修改-写回,Read-Modify-Write,简称RMW操作。以上的3个步骤,对应到Redis其实是3个命令,当存在并发时,就可能导致库存量错误了,如下图,库存量最终应该是8,但由于并发导致库存量最终是9:

在这里插入图片描述

2:如何解决并发问题

解决并发问题的核心点就是,让操作以原子性的方式执行,首先单命令Redis是天然支持的,另外还有就是lua脚本,对于lua脚本Redis会以原子性的方式执行,分别来看下。

2.1:单命令

对于RMW操作,正常伪代码可能如下:

在这里插入图片描述

这类代码,也有专门的名称,叫做临界代码块,即同时只能被一个线程执行的代码块,因为这类问题比较常见,所以Redis提供了incr和desc单命令来代替以上代码,如下:

127.0.0.1:6379> set age 99
OK
127.0.0.1:6379> incr age
(integer) 100
127.0.0.1:6379> decr age
(integer) 99
127.0.0.1:6379> decr age
(integer) 98

但是对于具有逻辑判断的场景,就无法简单的使用一个命令来完成了,此时我们就需要使用lua脚本。

2.2:lua脚本

考虑限流场景,比如点赞,每小时来自同一个IP的点赞数不能超过100个,此时代码可能如下:

if (containsKey(ip)) {
    int 点赞数 = get(ip);
    if (赞点数 > 100) {
        sout("点赞数超过100");
    } else {
        set(ip, 点赞数+1);
    }
} else {
    // 点赞数设置为1,并设置过期时间为3600秒
    set(ip, 1, 3600);
}

此时如果有来自同一IP的大量并发的话,最终的点赞数肯定会大于100,这不是我们想要的结果,此时,我们就可以将这块代码定义在lua脚本中,如rateLimitLua.script,可能如下:

IF containsKey(ip)) THEN
    点赞数 = get(ip);
    IF (赞点数 > 100) THEN
        sout("点赞数超过100");
    ELSE
        set(ip, 点赞数+1);
    END
ELSE 
    // 点赞数设置为1,并设置过期时间为3600秒
    set(ip, 1, 3600);
END

然后就可以通过eval来执行了redis.cli --eval rateLimitLua.script keys,args,并且以原子的方式执行。

写在后面

参考文章列表:

Redis 单线程 为何却需要事务处理并发问题 。

Redis事务、MULTI 命令和EXEC 命令 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/79201.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

nodejs+vue人事管理系统30n9o

开发语言:nodejs 框架:Express 数据库:mysql 数据库工具:Navicat11 开发软件:VS code 浏览器:谷歌浏览器 目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 …

使用VS2019开发调试Android动态库

1. 环境准备 1.1 安装JDK:jdk1.8.0_112 1.2 安装Android SDK SDK可以安装指定的platforms和ndk-bundle。为了兼容性考虑,单独安装了版本比较老的android-ndk-r10b 1.3 安装VS2019 安装VS2019并选择:使用C的移动开发。 1.4 连接开发手机…

基于Java+Mysql实现(web)大型企业管理系统【100010019】

第一章 系统概述 包括用户管理、权限管理、软件项目管理、软件模块管理、测试用例管理、测试任务分配、bug管理等功能。实现公司不同部门间团队协作,管理人员也能够更加有效的把控系统开发的进度。 本实验综合应用JavaWeb编程中的Servlet,JSP&#xff…

spring——Spring自动装配(基于注解)——前提了解——Spring的@Autowired注解为什么用在接口上 (转载)...

大家都知道Service注入的是实现类serviceImpl,那使用时怎么能获取到接口,而且还能调用到实现类的方法。 接口: public interface TestService{ public String test(); }实现类: Service public class TestServiceImpl imp…

Netty_04_消息协议设计与实战(实践类)

文章目录一、前言二、整体运行:先启动服务端,然后启动客户端,发送三条消息三、客户端和服务端3.1 客户端(重要)3.2 服务端(重要)3.3 编码和解码(了解即可)四、尾声一、前言 源码下载:https://www.syjshare.com/res/XEE10LTG 二、…

【Linux修炼】10.进程地址空间

每一个不曾起舞的日子,都是对生命的辜负。 进程地址空间本节目标1. 回顾C/C地址空间1.1 提出问题1.2 见问题产生的现象1.3 解释现象2. 虚拟地址空间2.1 感性理解虚拟地址空间 2.2 如何“画饼”2.3 地址空间的区域划分3. 进程地址空间与内存的关系3.1 虚拟地址和物理…

LabVIEW编程LabVIEW开发 ADAM-4056 DO模块例程与相关资料

LabVIEW编程LabVIEW开发 ADAM-4056 DO模块例程与相关资料 ​ADAM-4056SO是具有12通道自源型携带Modbus协议隔离数字输出模块。具有如下特点: ADO源电源故障检测 输入/输出类型:源式输出 12通道 数字输出:VCC: 1~35伏直流电&a…

基于Java+Mysql实现(WEB)宿舍管理系统【100010016】

数据库实践课程之宿舍管理系统 一、系统需求分析 1.1 系统描述 随着社会的发展以及教育水平的提高,当今社会在校生的数量越来越庞大,使用传统的方式对学生的信息进行管理效率非常低下。在互联网技术高度发达的今天,使用数据库技术对学生的…

Go 实现希尔排序算法及图解

耐心和持久胜过激烈和狂热。 哈喽大家好,我是陈明勇,今天分享的内容是使用 Go 实现希尔排序算法。如果本文对你有帮助,不妨点个赞,如果你是 Go 语言初学者,不妨点个关注,一起成长一起进步,如果本…

游戏开发51课 性能优化9

4.5 光照模型(Lighting/Illumination Model) 4.5.1 Flat Shading(平面着色) 根据表面法向量计算光照,并应用到整个面片上。速度最快,效果最差,容易暴露物体的多边形本质(下图&…

微服务框架 SpringCloud微服务架构 29 ES 集群 29.4 分布式新增和查询流程

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 SpringCloud微服务架构 文章目录微服务框架SpringCloud微服务架构29 ES 集群29.4 分布式新增和查询流程29.4.1 ES集群的分布式存储29.4.2 总…

鸿蒙手机卸载内置应用 adb连接

鸿蒙手机傻瓜式卸载内置应用 adb连接**傻瓜式删除鸿蒙系统内置应用,自己亲测有效。**准备物品准备软件准备工作教程开始:第一步第二步完成包名列表一般软件谷歌服务格外的注意连接错误**鸣谢**傻瓜式删除鸿蒙系统内置应用,自己亲测有效。 准…

缓存数据丢了,原来是Redis持久化没玩明白

📣📣📣📣📣📣📣 🎍大家好,我是慕枫 🎍前阿里巴巴高级工程师,InfoQ签约作者、阿里云专家博主,一直致力于用大白话讲解技术知识 &#x…

Windows下MySQL5.5升级5.7(或直接安装MySQL5.7)

Windows下MySQL5.5升级5.7(或直接安装MySQL5.7) 1、关闭MySQL服务: Ctrl shift Esc找到服务,找到下面的MySQL服务,停止服务。 2、卸载程序: 控制面板中卸载mysql5.5。 3、删除mysql5.5的安装目录及注…

Linux文件操作

文章目录前言什么是文件文件操作C语言文件操作接口文件操作系统调用接口文件描述符如何理解FILE和文件描述符的关系前言 本文主要介绍的是Linux系统下的文件操作和Linux的文件系统的机制,希望能够通过本文来增加读者对于文件操作的基本使用和理解。以及了解Linux系…

【大数据入门核心技术-Ambari】(一)Ambari介绍

一、什么是Ambari Apache Ambari是一种基于Web的工具,支持Apache Hadoop集群的供应、管理和监控。Ambari已支持大多数Hadoop组件,包括HDFS、MapReduce、Hive、Pig、 Hbase、Zookeeper、Sqoop和Hcatalog等。 Apache Ambari 支持HDFS、MapReduce、Hive、Pi…

C语言宏和预处理

C语言宏和预处理【1】include【2】【#pragma】【3】C #include【4】# 和 ## 操作符【5】宏替换【6】#line【7】#error【8】#undef【9】源码【10】结果【1】include #include本命令包含一个文件并在当前位置插入.一般尖括号意味着在标准库目录中搜索, #include “filename” 引…

【C语言与汇编】简单学学C到汇编代码

C语言与汇编 部分过程可参考C primer plus 本书余下的篇幅讨论源代码文件中的内容;本节讨论创建源代码文 件的技巧。有些C实现(如Microsoft Visual C、Embarcadero C Builder、Apple Xcode、Open Watcom C、Digital Mars C和Freescale CodeWarrior&…

精品基于SSM的民宿预订管理系统

《民宿预订管理系统》该项目含有源码、论文等资料、配套开发软件、软件安装教程、项目发布教程等 使用技术: 开发语言:Java 框架:ssm 技术:JSP JDK版本:JDK1.8 服务器:tomcat7 数据库:my…

云原生事件驱动框架(KnativeEventing)

事件驱动是指事件在持续事务管理过程中,进行决策的一种策略。可以通过调动可用资源执行相关任务,从而解决不断出现的问题。通俗地说是当用户触发使用行为时对用户行为的响应。在 Serverless 场景下,事件驱动完美符合其设计初衷之一&#xff1…