第 4 篇:Redis 缓存与分布式锁实现

一、Redis 在系统中的核心作用

在这里插入图片描述

  1. 票证信息缓存:将高频访问的票证数据(如状态、有效期)缓存至 Redis,减少数据库查询,提升验证响应速度。

  2. 分布式锁:在高并发场景下,防止同一张票被同时验证,确保 “一票一次” 机制的可靠性。

  3. 闸机状态缓存:实时存储闸机开关状态,便于前端监控与管理。

二、Redis 集成步骤
  1. 安装 StackExchange.Redis
dotnet add package StackExchange.Redis
  1. 注册 Redis 服务:在 Program.cs 中配置连接:
builder.Services.AddSingleton\<IConnectionMultiplexer>(ConnectionMultiplexer.Connect(builder.Configuration.GetConnectionString("Redis")));
  1. 封装 Redis 操作工具类
public class RedisHelper{private readonly IDatabase _db;public RedisHelper(IConnectionMultiplexer redis){_db = redis.GetDatabase();}// 设置缓存(带过期时间)public async Task SetAsync(string key, string value, TimeSpan? expiry = null){await _db.StringSetAsync(key, value, expiry);}// 获取缓存public async Task<string> GetAsync(string key){return await _db.StringGetAsync(key);}}
三、分布式锁实现

分布式锁核心特性

  • 互斥性:同一时间只有一个节点能获取锁。
  • 安全性:避免死锁(锁必须有过期时间),不能误删他人的锁。
  • 可用性:Redis 故障时仍能基本可用(如主从切换)。
  • 重入性:同一线程可重复获取锁(可选,视场景而定)。
public class RedisDistributedLock{private readonly IDatabase _db;private readonly string _lockPrefix = "lock:";public RedisDistributedLock(IConnectionMultiplexer redis){_db = redis.GetDatabase();}// 获取锁(返回锁标识,用于释放)public async Task<string> AcquireLockAsync(string resource, TimeSpan expiry){var lockKey = _lockPrefix + resource;var lockValue = Guid.NewGuid().ToString(); // 唯一标识,防止误释放// SET NX(不存在则设置)+ PX(过期时间)var acquired = await _db.StringSetAsync(lockKey, lockValue, expiry, When.NotExists);return acquired ? lockValue : null;}// 释放锁(Lua脚本保证原子性)public async Task ReleaseLockAsync(string resource, string lockValue){var lockKey = _lockPrefix + resource;var script = @"if redis.call('get', KEYS\[1]) == ARGV\[1] thenreturn redis.call('del', KEYS\[1])elsereturn 0end";await _db.ScriptEvaluateAsync(script, new RedisKey\[] { lockKey },new RedisValue[] { lockValue });}}

c

  • 缓存更新:票证状态变更(如使用后)时,同步更新 Redis 缓存。

  • 过期时间:票证缓存设置与票证有效期关联,避免缓存冗余。

  • 缓存穿透防护:对不存在的票证,缓存空值(短期过期),减少无效数据库查询。

五、缓存常见问题
问题描述解决方案
缓存穿透查询不存在的数据,穿透到DB1. 缓存空值(短期过期);2. 布隆过滤器预过滤不存在的key
缓存击穿热点key过期瞬间大量请求DB1. 互斥锁(查询时加锁,只让一个线程更新缓存);2. 热点key永不过期
缓存雪崩大量key同时过期,请求压垮DB1. 过期时间加随机值(分散过期);2. 服务熔断/降级;3. 缓存集群高可用

六、注意事项

  1. Redis 部署方式

    • 单机部署:锁性能高,但存在单点故障风险。
    • 主从+哨兵:提高可用性,但主从切换时可能出现“锁丢失”(可通过 Redisson 的 RedLock 算法缓解,但性能有损耗)。
  2. 锁超时处理

    • 锁过期时间需大于业务执行时间,避免业务未完成锁已释放。
    • 可使用“锁续期”机制(如 Redisson 的 Watch Dog),自动延长锁有效期。
  3. 缓存与锁的结合

    • 缓存更新时需加锁避免并发问题(如缓存击穿场景)。
    • 分布式锁的粒度应尽量小,避免影响性能。
总结
  • Redis 缓存:通过合理的缓存策略(如 Cache-Aside)和问题解决方案,可显著提升系统性能。
  • 分布式锁:基于 Redis 的 SET NX PX 命令可实现基础锁,生产环境推荐使用 Redisson 简化开发并避免潜在问题。

两者结合可有效解决分布式系统中的性能与并发安全问题。

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

北京天津唐山廊坊沧州打捞日记

北京天津唐山廊坊沧州打捞日记 打捞搜蚯蚓疏通 北京&#xff1a;护城河畔的情谊打捞 清晨&#xff0c;北京的护城河在朝阳的映照下泛着微光。我接到一位年轻小伙的电话&#xff0c;声音中满是焦急。原来&#xff0c;他与女友在河边约会时&#xff0c;不小心将女友送他的定情玉佩…

全志刷机工具:PhoenixSuit-全志芯片处理器-刷机工具安装包及最详细使用教程指南

全志刷机工具&#xff1a;PhoenixSuit-全志芯片处理器刷机工具安装包及最详细使用教程指南&#xff0c;此文章主要是分享机顶盒、电视盒子&#xff0c;全志芯片盒子&#xff08;其中包含全志处理器、全志芯片、全志CPU等等&#xff09;的刷机工具、刷机工具安装教程以及如何使用…

浅谈 VM 桥接模式:让虚拟机像真实电脑一样接入网络

在虚拟化环境中&#xff0c;虚拟机&#xff08;Virtual Machine, VM&#xff09;与外部网络之间的通信方式有多种&#xff0c;比如 NAT 模式、Host-Only 模式、桥接模式&#xff08;Bridged Networking&#xff09; 等。其中&#xff0c;桥接模式是最接近“真实物理机”网络行为…

计算机视觉(1)-图像采集设备选型全景表(工业 + 医疗 + 车载)

图像采集设备选型全景表&#xff08;工业 医疗 车载&#xff09;一份面向工程师的“场景—设备—协议”速查表1 工业 & 医疗 & 通用场景应用场景主流设备形态接口 / 协议典型性能突出优势致命短板动态范围工业检测AOI / 量测 / 缺陷工业相机 采集卡Camera Link HSCo…

计算机视觉(3)深度学习模型部署平台技术选型与全栈实践指南

一、部署平台概述与分类 深度学习模型部署平台的分类需兼顾技术特性与应用场景的适配性&#xff0c;基于“技术定位-场景适配”双维度分类法&#xff0c;可将其划分为通用开源框架、云厂商服务及专用边缘工具三大类&#xff0c;各类别在设计目标、核心能力与场景覆盖上呈现显著…

Scratch编程:枪战游戏(附源码)

&#x1f3ae; 操作说明 W / A / S / D 或 方向键&#xff1a;移动 C&#xff1a;滑铲 空格键&#xff1a;取消滑铲 鼠标点击&#xff1a;开火 数字键 1 / 2 / 3 / 4&#xff1a;切换武器 G&#xff1a;快速使用道具 F&#xff1a;近战攻击 Q&#xff1a;瞄准 / 使用技能…

应急响应复现

一、前言&#xff1a;当企业发生黑客入侵、系统崩溃或其它影响业务正常运行的安全事件时&#xff0c;急需第一时间进行处理&#xff0c;使企业的网络信息系统在最短时间内恢复正常工作&#xff0c;进一步查找入侵来源&#xff0c;还原入侵事故过程&#xff0c;同时给出解决方案…

分布式事务Seata TCC模式篇

介绍 ​ 官网: https://seata.apache.org/zh-cn/docs/user/mode/tcc ​ 回顾Seata AT 模式基于 支持本地 ACID 事务 的 关系型数据库&#xff0c;如下&#xff1a; 一阶段 prepare 行为&#xff1a;在本地事务中&#xff0c;一并提交业务数据更新和相应回滚日志记录。二阶段 c…

Day37--动态规划--52. 携带研究材料(卡码网),518. 零钱兑换 II,377. 组合总和 Ⅳ,57. 爬楼梯(卡码网)

Day37–动态规划–52. 携带研究材料&#xff08;卡码网&#xff09;&#xff0c;518. 零钱兑换 II&#xff0c;377. 组合总和 Ⅳ&#xff0c;57. 爬楼梯&#xff08;卡码网&#xff09; 本文全部都是 ” 完全背包 “ 问题&#xff0c;从零到入坑&#xff0c;从入坑到爬出来。 本…

Linux文件操作

Linux文件Linux下的文件类型b 块设备文件---->存储类设备&#xff08;硬盘&#xff09;c 字符设备文件--->输入输出设备d 目录文件--->文件夹- 普通文件--> xxx.c xxx.h xxx.txt xxx.jpg xxx.mp4 a.outl 软链接文件-->快捷方式s 套接字文件-->网络通信p 管道…

Linux epoll 触发模式详解:LT vs ET

两种核心触发模式 1. 水平触发 (Level-Triggered, LT) 工作方式: 当文件描述符处于就绪状态时,epoll 会持续通知 只要状态未改变,每次调用 epoll_wait 都会返回该描述符 特点: c // 内核处理逻辑 (ep_send_events_proc) if (!(epi->event.events & EPOLLET)) { /…

STM32学习笔记6-TIM-2输出比较功能

第二部分&#xff0c;定时器的输出比较功能OC&#xff08;Output Compare&#xff09;输出比较输出比较可以通过比较CNT与CCR寄存器值的关系&#xff0c;来对输出电平进行置1、置0或翻转的操作&#xff0c;用于输出一定频率和占空比的PWM波形每个高级定时器和通用定时器都拥有4…

MATLAB核心技巧:从入门到精通

一 1.数值 显示 格式 format style 设置 eg: pi format longE; or 2.清除指令 clc 清除命令行窗口 clear 清除工作区 cls 3.搜索路径设置 path(path,E:\ads\) or addpath 4.M文件 用户把要实现的命令写在一个以.m为扩展的文件中&#xff0c;然后由matlab系统进行解读…

AnyDesk远程工具免费版,v9.5.110绿色便携版,秒连远程桌面,剪贴板同步超实用

[软件名称]: AnyDesk远程工具免费版 [软件大小]: 7.5 MB [软件大小]: 夸克网盘 | 百度网盘 软件介绍 AnyDesk 让远程工作变得轻而易举。无论您身处办公室的另一端还是世界的另一侧&#xff0c;只需在设备上下载、安装并启动 AnyDesk.exe&#xff0c;即可轻松访问远程屏幕。…

AI: 给Gemini CLI配上“说明书”, 精通的GEMINI.md项目记忆

嘿&#xff0c;各位技术同好&#xff01;今天我们来聊一个能极大提升AI编程助手效率的酷炫功能——Google Gemini CLI 中的 GEMINI.md 文件。 在日常开发中&#xff0c;我们越来越依赖像 Gemini 这样的 AI 助手来帮我们写代码、调试 Bug 甚至重构项目。但大家是否遇到过这种情况…

[激光原理与应用-205]:光学器件 - LD与DFB的比较

一、相同点核心原理均基于半导体材料的受激辐射机制&#xff0c;通过电子-空穴复合产生光子。依赖谐振腔实现光反馈与放大&#xff0c;形成激光振荡。采用电泵浦方式驱动&#xff0c;电流注入激发载流子&#xff0c;实现粒子数反转。材料体系主要使用III-V族化合物半导体&#…

Cursor手机版:一半是神,一半是坑

大家好&#xff0c;我是羊仔&#xff0c;专注AI工具、智能体、编程。今天想和大家聊的这个工具&#xff0c;叫Cursor&#xff0c;可能很多朋友已经不陌生了&#xff0c;它作为一款AI原生代码编辑器&#xff0c;之前可谓是风光无两。但最近&#xff0c;它又搞了点新花样&#xf…

康养休闲旅游服务虚拟仿真实训室:筑牢技能人才培养的数字基石

随着康养休闲旅游行业数字化、网络化、智能化发展趋势的深化&#xff0c;行业对高素质技能人才的实践能力和数字素养提出了更高要求。康养休闲旅游服务虚拟仿真实训室作为对接行业需求、创新实践教学模式的重要载体&#xff0c;正成为中等职业教育康养休闲旅游服务专业人才培养…

【Python 高频 API 速学 ⑤】

一、为什么把字典和集合放同一篇&#xff1f; • 底层都是哈希表&#xff0c;API 设计高度对称。 • 日常任务无非「读-写-去重-集合运算」&#xff0c;这 5 个方法就能打穿。二、三件套 & 二板斧一览名称作用返回值原地&#xff1f;dict.get(key, default)安全读取值或 de…

el-tree方法的整理

1.点击树的文字不要收缩仅点击图标的时候收缩 expand-on-click-node&#xff1a;是否在点击节点的时候展开或者收缩节点&#xff0c; 默认值为 true&#xff0c;如果为 false&#xff0c;则只有点箭头图标的时候才会展开或者收缩节点。<el-tree:expand-on-click-node"f…