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

闸机控制系统从设计到实现全解析:第 4 篇:Redis 缓存与分布式锁实现

第 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.lryc.cn/news/611184.html

相关文章:

  • STM32设置GPIO模式
  • Dify工作流三剑客:参数提取、变量赋值与聚合详解
  • Starrocks中的 Query Profile以及explain analyze及trace命令中的区别
  • Linux系统:基础I/O
  • 基于python的二手车价格预测及可视化系统,采用集成学习算法和diango框架
  • [按键精灵]
  • Pytorch基础入门2
  • AlmaLinux8 平替 manylinux_2_28-python 的 GPG密钥管理、安装 cuda sdk
  • gRPC Keepalive 机制详解与最佳实践
  • 微软Dragon Ambient eXperience (DAX) 深度解析
  • Linux 调度器函数sched_*系统调用及示例
  • Java JDBC连接池深度解析与实战指南
  • Transformer的并行计算与长序列处理瓶颈
  • Linux lvm逻辑卷管理
  • 猜数字游戏 Java
  • 【C++】模板深入进阶
  • Java技术栈/面试题合集(13)-网络篇
  • [Linux]学习笔记系列 -- [arm]boot
  • Android 之 Kotlin 和 MVVM 架构的 Android 登录示例
  • 腾讯云对象存储服务COS
  • QtPromise第三方库的介绍和使用
  • 人工智能领域、图欧科技、IMYAI智能助手2025年1月更新月报
  • ubuntu24中部署k8s 1.30.x-底层用docker
  • 相机拍摄的DNG格式照片日期如何修改?你可以用这款工具修改
  • Android异常信号处理详解
  • 【网络运维】Linux:系统启动原理与配置
  • Coze开源了!意味着什么?
  • 在Linux上部署RabbitMQ、Redis、ElasticSearch
  • 无监督学习聚类方法——K-means 聚类及应用
  • NFS CENTOS系统 安装配置