redis高并发问题以及解决方案

news2024/10/6 0:32:51

文章目录

  • 1.高并发读操作问题
    • 1.1缓存穿透
    • 1.2缓存击穿
    • 1.3缓存雪崩
  • 2.高并发写问题
    • 2.1数据库双写不一致问题
    • 2.2双写不一致问题解决方案
      • 2.2.1延时双删
      • 2.2.2队列
      • 2.2.3分布式锁

1.高并发读操作问题

1.1缓存穿透

指访问一个缓存和数据库中都不存在的key,由于这个key在缓存中不存在,则会到数据库中查询,数据库中也不存在该key,无法将数据添加到缓存中,所以每次都会访问数据库导致数据库压力增大。

  • 解决方法
  1. 将空key添加到缓存中。
  2. 一般对于这种访问可能由于遭到攻击引起,可以对请求进行身份鉴权、数据合法行校验等。

1.2缓存击穿

指大量请求访问缓存中的一个key时,该key过期了,导致这些请求都去直接访问数据库,短时间大量的请求可能会将数据库击垮。

  • 解决方法
  1. 添加互斥锁或分布式锁,让一个线程去访问数据库,将数据添加到缓存中后,其他线程直接从缓存中获取。
  2. 热点数据key不过期,定时更新缓存,但如果更新出问题会导致缓存中的数据一直为旧数据。

1.3缓存雪崩

指在系统运行过程中,缓存服务宕机或大量的key值同时过期,导致所有请求都直接访问数据库导致数据库压力增大。

  • 解决方法
  1. 将key的过期时间打散,避免大量key同时过期。
  2. 对缓存服务做高可用处理
  3. 加互斥锁,同一key值只允许一个线程去访问数据库,其余线程等待写入后直接从缓存中获取。

2.高并发写问题

2.1数据库双写不一致问题

  • 正常请求(双写)
    在这里插入图片描述
  • 异常情况, 场景1, 更新缓存
    在这里插入图片描述
  • 正常情况下(写,读)

在这里插入图片描述
缓存和数据库数据不一致问题情况2
在这里插入图片描述

2.2双写不一致问题解决方案

2.2.1延时双删

修改完数据库数据之后删除对应缓存,延时时候再删缓存

2.2.2队列

采用队列的方式将并行请求转换成串行(影响性能)

2.2.3分布式锁

Redis实现分布式锁的7种方案,及正确使用姿势!

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

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

相关文章

[附源码]Node.js计算机毕业设计大学生心理健康咨询系统Express

项目运行 环境配置: Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境:最好是Nodejs最新版,我…

[附源码]Python计算机毕业设计吃到撑零售微商城Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等…

R语言里的非线性模型:多项式回归、局部样条、平滑样条、 广义相加模型GAM分析

总览 在这里,我们放宽了流行的线性方法的假设。最近我们被客户要求撰写关于非线性模型的研究报告,包括一些图形和统计输出。有时线性假设只是一个很差的近似值。有许多方法可以解决此问题,其中一些方法可以通过使用正则化方法降低模型复杂性…

计算机网络——应用层

应用层概述 计算机网络各层所解决的问题 我们在浏览器的地址中输入某个网站的域名后,就可以访问该网站的内容,这个就是万维网WWW应用,其相关的应用层协议为超文本传送协议HTTP 用户在浏览器地址栏中输入的是“见名知意”的域名,而…

115-127-mysql-高级篇-索引及结构

115-mysql-高级篇-索引及调优篇: 索引及调优篇 1、索引的数据结构 1. 索引及其优缺点 1.1 索引概述 索引的定义为:索引(Index)是帮助MySQL高效获取数据的数据结构。 **索引的本质:**索引是数据结构。“排好序的快…

Java项目:SSM在线蛋糕商城销售网站项目

作者主页:源码空间站2022 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 本项目为前后台项目,前台为普通用户登录,后台为管理员登录; 用户角色包含以下功能: 查看所有蛋…

[附源码]Python计算机毕业设计宠物托管系统Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等…

redis--主从复制、哨兵和cluster集群

一、介绍redis 在Redis中,实现高可用的技术主要包括持久化、主从复制、哨兵和cluster集群,下面分别说明它们的作用,以及解决了什么样的问题。 持久化: 持久化是最简单的高可用方法(有时甚至不被归为高可用的手段&…

[网络工程师]-网络安全-数字签名和数字证书

随着《中华人民共和国电子签名法》这部法律的出台和实施,电子签名获得了与传统手写签名和盖章同等的法律效力,这意味着经过电子签名的电子文档在网上传输有了合法性。电子签名并非是书面签名的数字图像化,而是一种电子代码。联合国贸发会的《…

单源最短路径问题——分支限界法(Java)

单源最短路径问题——分支限界法(Java) 文章目录单源最短路径问题——分支限界法(Java)1、 前置芝士1.1 分支限界法求解目标1.2 分支限界法引言1.3 分支限界法基本思想1.4 两种典型的解空间树2、分支限界法解题过程2.1 算法要点2.…

java 实现对数据表的备份与还原(备份与还原 到服务器中)

java备份还原表数据 背景 需求:这个功能还是费了我一段时间才完成,大体的需求是这样的。 首先是 分模块,每个模块有不同的几个表,备份的时候就按照模块来备份数据,相当于一次性备份多张表的数据了,模块 和…

攻防世界-baigeiRSA

1.下载附件,得到压缩包,解压得到两个文件。 import libnum from Crypto.Util import number from secret import flagsize 128 e 65537 p number.getPrime(size) q number.getPrime(size) n p*qm libnum.s2n(flag) c pow(m, e, n)print(n %d % …

(已更新)Discuz手机模板:NVBING5-APP手机版,界面美观大方,可封装安卓/苹果APP,模板文件+插件+分类信息导入文件

Discuz手机模板:NVBING5-APP手机版——是一款界面美观大方的完整Discuz手机模板,附带模板插件分类信息导入文件详细的安装说明模块说明。 功能介绍 *支持封装安卓APP、苹果APP,原生微信登录、分享等几十项功能 *支持视频上传至优酷云或本地…

水溶性荧光团磺酸基-花青素Cy7 酪酰胺,Tyramide-Sulfo-Cy7

磺酸基-花青素Cy7 酪酰胺是一种水溶性荧光团,用于近红外光谱部分。由于其结构中存在三亚甲基桥,使其量子产率比其他七甲基菁高。氟化染料是理想的体内成像应用。一个非氟化版本,Cyanine7,也可用。 『英文名称』:Tyram…

基础SQL语法语句大全(一篇学会所有SQL语句)

如:select distinct name from student; 如:select name,salary from employee where deptno 3; 如:select * from employees where deptno 3 and salary>-5000;(两个条件同时满足) select * from employees where (deptno 3 or depton…

HARDiNFO Pro 8.0 绿色版-轻便版

HARDiNFO 一体化系统信息、诊断和基准测试 主要特点 硬件清单、计算机管理、基准测试和网络监控 硬件库存 获取有关您的 PC 硬件组件和外围设备的详细系统信息,例如;CPU、内存、主板、显示适配器、HDD/SSD 磁盘驱动器、显示器、笔记本电池、操作系统驱动…

[附源码]JAVA毕业设计医院门诊挂号系统(系统+LW)

[附源码]JAVA毕业设计医院门诊挂号系统(系统LW) 项目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术…

【QT 5 学习笔记-学习绘图相关+画线图形等+绘图事件+基础学习(1)】

【QT 5 学习笔记-学习绘图相关画线图形等绘图事件基础学习(1)】1、说明2、实验环境3、参照学习链接4、自己的学习与理解5、学习与实践代码。(1)建立基础工程。(2)加入绘图事件与包含库(3&#x…

自然语言处理(NLP)数据集汇总 2(附下载链接)

🎄🎄【自然语言处理NLP】简介 🎄🎄 自然语言处理(Natural Language Processing, NLP)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有效通信的各种理论和方法。自然语言处理是一门…

真是绝了!git标星9K

能力f(认知,洞察,实践,经验总结) 不知道你到了哪个阶段了呢? 架构是软件工程的实践艺术,要化理想为现实,不是空中楼阁。懂得再多的设计理念、方法论,光说不练还是假把式…