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

分布式缓存获取以及设置

 1. 通用代码

   public SysUser getCache(String sysUserId) {String cacheKey = "litgery:warehouse:" + sysUserId;// 尝试从缓存中获取数据CacheData cacheData = redisUtils.get(cacheKey);if (null != cacheData) {if (Boolean.TRUE.equals(cacheData.getExist())) {return cacheData.getSysUser();} else {return null;}}//   RedisLockClient 获取锁RLock rLock = redisLockClient.getRLock("litgery:warehouse:lock");try {// 尝试获取锁,如果锁已被其他线程持有,则等待rLock.lock();// 再次检查数据是否存在,因为可能在等待锁的过程中,其他线程已经填充了数据cacheData = redisUtils.get(cacheKey);if (null != cacheData && Boolean.TRUE.equals(cacheData.getExist())) {return cacheData.getSysUser();}//随机过期时间,随机生成0.5小时-1小时之内的时间(减少缓存同时失效的机会)Long expireTime = CacheUtils.getRandomExpireTimeInOneOrTowDay();SysUser sysUser = sysUserService.getById(sysUserId);if (null == sysUser) {// 如果数据仍然不存在,从数据库中获取数据并填充缓存,避免不存在的数据一直请求打到数据库CacheData emptyCache = new CacheData();emptyCache.setExist(Boolean.FALSE);redisUtils.setEx(cacheKey, emptyCache, expireTime);return null;}CacheData cache = new CacheData();cache.setSysUser(sysUser);cache.setExist(Boolean.TRUE);redisUtils.setEx(cacheKey, cache, expireTime);return sysUser;} finally {// 释放锁rLock.unlock();}}

 

redisUtils 为redis工具类,例如:设置缓存获取缓存等等。
redisLockClient  为:RedisLockClient 的分布式锁

2.整体步骤

1. 获取缓存,若有值直接返回

2.获取一个分布式锁。

3. 加锁

4. 再次检查数据是否存在,因为可能在等待锁的过程中,其他线程已经填充了数据

5.从数据库获取。若为空,设置一个空值到redis。若不为空,直接返回,最好设置随机过期时间

6.释放锁

可优化的点,可添加布隆过滤器

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

相关文章:

  • SMO算法,platt论文的原始算法及优化算法
  • 2.3 openCv -- 对矩阵执行掩码操作
  • 【Django】 js实现动态赋值、显示show隐藏hide效果
  • qt--做一个拷贝文件器
  • Eclipse 搭建 C/C++ 开发环境以及eclipse的使用
  • 【初阶数据结构】复杂度算法题篇
  • 20240725项目的maven环境报红-重新配置maven
  • 若依 ruoyi poi Excel合并行的导入
  • 优化算法:1.遗传算法(GA)及Python实现
  • 企业化运维(8)Docker容器技术
  • Unity C#底层原理(二)
  • 计算机网络-配置路由器ACL(访问控制列表)
  • 51单片机嵌入式开发:20、STC89C52R基于C51嵌入式点阵广告屏的设计
  • VLC输出NDI媒体流
  • WiFi 局域网通信 - 发现服务和解析
  • ChatGPT建议前端学习计划
  • YOLO5项目目录最强解析
  • 【python】sklearn基础教程及示例
  • Linux:传输层(2) -- TCP协议(2)
  • AcWing 802. 区间和
  • 实验2-2-1 温度转换
  • Spark实时(六):Output Sinks案例演示
  • 在SQL编程中DROP、DELETE和TRUNCATE的区别
  • 【AI大模型】Prompt 提示词工程使用详解
  • 学习记录day18——数据结构 算法
  • 一篇文章带你学完Java所有的时间与日期类
  • 利用GPT4o Captcha工具和AI技术全面识别验证码
  • 大学生算法高等数学学习平台设计方案 (第一版)
  • 机器学习算法与Python实战 | 两行代码即可应用 40 个机器学习模型--lazypredict 库!
  • 使用WebSocket协议调用群发方法将消息返回客户端页面