使用Redis实现缓存及对应问题解决
一、为什么需要Redis作缓存?
在业务场景中,如果有些数据需要极高频的存取,每次都要在mysql中查询的话代价太大,假如有一个存在于客户端和mysql之间的存储空间,每次可以在这空间中进行存取操作,就会减轻mysql的压力,而redis速度快效率高的特点是实现缓存的好选择。

在没有加入缓存的时候,客户端和服务端的工作流程如图所示

加入缓存之后, 在每次查询数据的时候,先在redis中查询,如果有就直接返回,如果没有再去mysql中查询,在mysql中查询到之后先写入到redis中,在返回给客户端。
二、实现加入缓存。

三、缓存的更新策略。



先删除缓存,在更新数据库

假如在最开始的时候,缓存中和数据库中的值都是10,在正常的操作流程下,会得到如下的结果。

但是在特殊情况下,如果在线程一执行的时候,线程二插入进来,就会造成下图的情况。

而这种情况发生的概率还是很高的,因为更新数据库的操作还是相对于写入缓存来说是很慢的,在这个过程中,极有可能发生这种情况。
先操作数据库,在删除缓存

在正常的情况下,发生的是如下的操作

这种情况的特殊情况是:当缓存中的值失效,缓存中没有值,数据库中的值还是10,会发生下面这种情况。

但是这种情况的概率是小于前者的,因为写入缓存的时间明显是小于更新数据库的时间的,在这么短的时间内,发生更新数据库的操作的概率是很小的。
综上所述,应该先操作数据库再删除缓存。
四、缓存穿透。
缓存穿透指的是客户端请求的数据在缓存中和数据库都不存在,这样的缓存永远不会生效,这些请求都会打到数据库。

短期不一致的原因:当查询时没有的id以null存入到redis中,假如这时候真正的相同id存入到了数据库,在查询时就只能查询到redis中的null值,直到TTL过期,解决办法是可以手动的在数据库新增的值更新放入redis中。

布隆过滤器是一种基于哈希的算法,将二进制存入到布隆过滤器中,但它只是一种概率过率,他告诉你不存在的时候一定不存在,但是当告诉你存在时,却不一定存在。

要解决缓存穿透,业务逻辑就会变成这个样子。




五、缓存雪崩。
缓存雪崩是指在同一时段大量的缓存key同时失效或者redis服务宕机,导致大量的请求到达数据库,带来巨大压力。

六、缓存击穿。

缓存击穿实现不用考虑缓存击穿的问题


互斥锁

获取锁和释放锁的逻辑代码实现




因为就算抛异常也要释放锁,所以把释放锁的代码放在finally中。

逻辑过期实现





相关文章:
使用Redis实现缓存及对应问题解决
一、为什么需要Redis作缓存? 在业务场景中,如果有些数据需要极高频的存取,每次都要在mysql中查询的话代价太大,假如有一个存在于客户端和mysql之间的存储空间,每次可以在这空间中进行存取操作,就会减轻mys…...
【穿透科技】P2P穿透模块介绍
P2P穿透+一站式音视频解决方案路过看风景P2P隧道模块(pgLibTunnel) 1.功能介绍 P2P隧道是在Peergine中间件基础上实现的一个TCP隧道应用(通过P2P来传输TCP流量),包括服务器和客户端程序。它可以协助从公网或者从另一私网访问某个私网内部的计算机和网络设备。其优点是无需…...
中国第二批,11个大模型备案获批
加上首批的 10 余个大模型,目前已有超过 20 个大模型获得审批。 据钛媒体独家报道,国内第二批通过备案的AI大模型包括11家公司,部分已面向全社会开放服务。加上首批的10余个大模型,目前已有超过20个大模型获得备案。 新一批备案…...
一文搞定多端开发,做全栈大牛 附三大企业实战项目
一个功能三套代码 一改需求就是加不完的班? 不存在的,告别改改改 拥抱多端开发 一套代码搞定多个平台 高效开发:一套代码,多端通用 根据统计数据,全球移动设备用户数已经超过了50亿。随着智能手机、平板电脑等移动…...
带有滑动菜单指示器的纯 CSS 导航选项卡
效果展示 CSS 知识点 filter 属性回顾 transition 属性回顾 使用单选框实现导航菜单的思路 单选框当点击完成后就会有一个:checked属性,可以利用这个属性来实现导航菜单底部滑动块的滑动动画和当前菜单项激活状态的管理。 整体页面结构 <div class"tab…...
Java学习笔记41——接口组成更新
接口祖成更新 接口组成更新接口组成更新概述接口的组成接口中的默认方法接口中的静态方法接口中的私有方法 接口组成更新 接口组成更新概述 接口的组成 常量 public static final 抽象方法 public abstract 默认方法(Java8)静态方法(Java8…...
iview实现table里面每行数据的跳转
我的需求是跳转到第三方网站,看官方是写了如何跳转站内路由,不符合我的要求,在csdn发现了一篇文章,我贴一下代码 <template><Table border :columns"ReportColumns" :data"ReportData"><templ…...
Docker快速搭建Drupal内容管理系统并远程访问
🎬 鸽芷咕:个人主页 🔥个人专栏:《Linux深造日志》《C干货基地》 ⛺️生活的理想,就是为了理想的生活! 文章目录 前言1. Docker安装Drupal2. 本地局域网访问3 . Linux 安装cpolar4. 配置Drupal公网访问地址5. 公网远程访问Drupal…...
Ansible优化大全
文章目录 一、关闭系统信息收集二、开启加速 Ansible 执行速度修改配置文件/etc/ansible/ansible.cfg由于该功能与sudo冲突,必须关闭 requiretty 选项方法一方法二 参考文章: https://blog.csdn.net/o0o0o0D/article/details/110998873 一、关闭系统信息…...
Python|OpenCV-图像的添加和混合操作(8)
前言 本文是该专栏的第8篇,后面将持续分享OpenCV计算机视觉的干货知识,记得关注。 在使用OpenCV库对图像操作的时候,有时需要对图像进行运算操作,类似于加法,减法,位操作等处理。而本文,笔者将针对OpenCV对图像的添加,混合以及位操作进行详细的介绍说明和使用。 下面,…...
Vue3+vite+cesium环境搭建
引言 目前有不少vue3cesium的配置教学,存在以下两个问题: (1)vue3cli方式,随着项目的迭代,npm run serve 启动调试很慢; (2)vue3vite 确实能将调试启动提升不少的&…...
metaObjecthandler 的基本理解与使用(自动插入更新人和创建人)
metaObjecthandler 的基本理解与使用(自动插入更新人和创建人) mysql 自动插入更新和修改时间 更新字段信息 ALTER TABLE test MODIFY create_date timestamp not null default CURRENT_TIMESTAMP; ALTER TABLE test MODIFY update_date timestamp not null default CURRE…...
SpringBoot与ES7实现多条件搜索
SpringBoot与ES7实现多条件搜索 利用Kibana内置的航班数据,查询从威尼斯到中国按票价升序排列的前10条航班数据。 第一步,新建SpringBoot功能,pom.xml引入四个依赖。 <dependency><groupId>org.elasticsearch.client</groupI…...
【排序算法】 快速排序(快排)!图解+实现详解!
🎥 屿小夏 : 个人主页 🔥个人专栏 : 算法—排序篇 🌄 莫道桑榆晚,为霞尚满天! 文章目录 📑前言🌤️快速排序的概念☁️快速排序的由来☁️快速排序的思想☁️快速排序的实…...
急招开发、安全工程师实习生
信息安全工程师-实习生 公司:四川久远银海软件股份有限公司 工作职责 1、负责对公司WEB应用、APP、小程序、公众号等产品进行安全渗透测试; 2、负责对参与攻防演练、护网行动的项目组提供安全技术支撑; 3、负责提供基线核查、风险评估、主…...
数据结构与算法—插入排序选择排序
目录 一、排序的概念 二、插入排序 1、直接插入排序 直接插入排序的特性总结: 2、希尔排序 希尔排序的特性总结: 三、选择排序 1、直接选择排序 时间复杂度 2、堆排序—排升序(建大堆) 向下调整函数 堆排序函数 代码完整版: …...
基于词云图的短信热词数据可视化
热词统计:短信、邮件、微信、QQ、微博、电商评价、新闻、各行业热词(旅游、世界杯、战争、考研等)、热点事件等场景。 展示模型:给定多段文本,绘制出词云图。 核心思想:根据样本集中的文本包含的高频词…...
Linux/centos上如何配置管理Web服务器?
Linux/centos上如何配置管理Web服务器? 1 Web简单了解2 关于Apache3 如何安装Apache服务器?3.1 Apache服务安装3.2 httpd服务的基本操作 4 如何配置Apache服务器?4.1 关于httpd.conf配置4.2 常用指令 5 简单实例 1 Web简单了解 Web服务器称为…...
Java EE进阶2
包如果下载不下来怎么办? 1,确认包是否存在 2.如果包存在就多下载几次 3.如果下载了很多次都下载不下来,看看是不是下面几步出现了问题? 1)是否配置了国内源 settings.xml 2)目录是否为全英文,存在中文的话就修改路径 3)删除本地仓库的 jar 包,重新下载(可能由于网络的原…...
最新AI系统ChatGPT源码+AI绘画系统源码+支持GPT4.0+Midjourney绘画+搭建部署教程+附源码
一、AI创作系统 SparkAi创作系统是基于OpenAI很火的ChatGPT进行开发的Ai智能问答系统和Midjourney绘画系统,支持OpenAI-GPT全模型国内AI全模型。本期针对源码系统整体测试下来非常完美,可以说SparkAi是目前国内一款的ChatGPT对接OpenAI软件系统。那么如…...
为什么92%的MCP 2026审计报告被监管驳回?——4大元数据缺失陷阱与ISO/IEC 27001:2022对齐方案
更多请点击: https://intelliparadigm.com 第一章:MCP 2026权限审计报告的监管驳回现状与根本动因 近期,多家金融机构提交的MCP 2026权限审计报告连续遭遇监管机构驳回,驳回率高达68.3%(据2024年Q2银保监科技合规通报…...
八大网盘直链解析工具:告别限速,轻松获取真实下载地址
八大网盘直链解析工具:告别限速,轻松获取真实下载地址 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动…...
Pearcleaner:macOS应用清理的终极解决方案,彻底告别数字残留
Pearcleaner:macOS应用清理的终极解决方案,彻底告别数字残留 【免费下载链接】Pearcleaner A free, source-available and fair-code licensed mac app cleaner 项目地址: https://gitcode.com/gh_mirrors/pe/Pearcleaner 你是否曾在macOS上删除应…...
2026软考高级架构论文预测——论基于AI融合的架构设计
论基于AI融合的架构设计 摘要 在数字化转型深度推进的当下,AI技术已成为驱动系统升级、提升业务价值的核心引擎,将AI能力与传统系统架构深度融合,是破解业务效率瓶颈、实现智能化决策的关键路径。本文结合笔者参与的省级人工智能巡考系统(SX-MAPS)建设项目,阐述基于AI融…...
图解『简单路径第二大边权』:用最小生成树+启发式合并解决图论难题(附C++代码)
图解『简单路径第二大边权』:用最小生成树启发式合并解决图论难题(附C代码) 在算法竞赛和高级图论问题中,求解两点间简单路径的第二大边权是一个经典但颇具挑战性的问题。本文将带你从最小生成树的基础出发,通过启发式…...
微信聊天记录永久保存终极指南:WeChatExporter三步搞定数据备份
微信聊天记录永久保存终极指南:WeChatExporter三步搞定数据备份 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否担心手机丢失后那些珍贵的聊天记录再也…...
AMD Ryzen处理器调试终极指南:掌握硬件级性能调优完整教程
AMD Ryzen处理器调试终极指南:掌握硬件级性能调优完整教程 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:…...
机器学习-第二章 KNN算法
标题 第二章 KNN算法 目录 KNN算法简介 KNN思想、分类和回归问题处理流程 KNN算法API介绍 分类、回归实现 距离度量 常用距离计算方法 特征预处理 归一化 标准化 鸢尾花识别案例 超参数选择方法 交叉验证、网格搜索、手写数字识别 学习目标 1.理解k近邻算法的思想 2.知道k近邻算…...
Windows 安装 Hermes Agent 对接微信机器人-养马教程
Hermes Agent是龙虾之后的又一热门工具,他是具备内置学习循环的自主智能体。本文介绍在Windows11 安装 Hermes Agent 并对接微信工具 官方文档:https://hermes-agent.nousresearch.com/ 1. 安装前准备 1.1 Windows 侧要求 windows本文基于wls安装&…...
用 CDS View 做 TransientProvider,在 Query Designer 里把技术名和字段描述彻底讲清楚
最近在做 SAP S/4HANA Embedded Analytics 相关建模时,一个很容易被忽略的问题又冒出来了,ABAP CDS View 在后台看起来字段名很清楚,到了 BW Modeling Tools Query Designer 或者 BEx Query Designer 里,字段技术名却变长了,字段描述有时来自 CDS,有时来自 Data Element,…...
