Redis 实战 问题

前言


 相关系列

  • 《Redis & 目录》
  • 《Redis & 实战 & 源码》
  • 《Redis & 实战 & 总结》
  • 《Redis & 实战 & 问题》
     
     

什么缓存击穿?怎么避免?


    所谓缓存击穿是指请求因缓存失效而直接访问数据库的情况,由于热点数据访问者众多的原因,该情况会有很大概率导致数据库压力在短时间内骤增,从而影响程序的性能乃至令其崩溃…避免缓存击穿的常用解决方案如下:

  • 设置热点数据永不过期;
  • 对向数据库请求的过程加互斥锁。
     
     

什么是缓存雪崩?怎么避免?


    所谓缓存雪崩是缓存击穿的并发情况,即短时间内有大量缓存失效而导致更大数量的请求直接访问数据库…避免缓存雪崩的常用解决方案如下:

  • 设置热点数据永不过期;
  • 为热点数据设置不同的存活时间;
  • 使用惰性缓存方案,确保热点数据只在使用时才被缓存,从而分散热点数据的缓存时间;
  • 对向数据库请求的过程加互斥锁;
  • 将热点数据的缓存更新交由专属的后台线程处理,而后台线程则需频繁检查缓存是否失效,并在失效时及时加载缓存(不推荐)。
     
     

什么是缓存穿透?怎么避免?


    所谓缓存穿透是指在缓存&数据库都不存在指定数据的情况下请求持续向数据库访问而导致数据库压力增大的情况…避免缓存传统的常用解决方案如下:

  • 对向数据库请求的过程加互斥锁;
  • 在数据库不存在热点数据的情况下缓存标识不存在的默认数据。不建议存null,因为存null存在两意性,建议存空对象;
  • 在程序层面对不合法的数据键进行拦截;
  • 采用布隆过滤器缓存所有已存在数据键的哈希值,从而过滤掉键不存在的请求。
     
     

什么是缓存预热?


    所谓缓存预热是指在程序上线时便将热点数据加载至缓存中,从而避免请求向数据库访问的情况发生。注意!预热的数据通常不设置过期时间,因为其失效会因为难以“快速”恢复而导致程序不可用。也因此如果程序使用了缓存预热,那么Redis的淘汰策略也要注意不要覆盖到永久存活的数据上…缓存预热的常用解决方案如下:

  • 编写相应的数据预热接口,并在程序上后手动调用;
  • 在程序自动调用数据预热接口;
  • 定时器定时调用数据预热接口。
     
     

什么是缓存降级?


    所谓缓存降级是指在缓存服务器宕机时直接返回默认数据的情况。在高并发环境中,缓存服务器宕机会在无异常处理的情况下导致程序直接崩溃;或是在有异常处理的情况下导致请求直接向数据库访问,并进一步造成程序性能骤降乃至崩溃的情况发生。而为了避免上述情况程序则可以使用缓存降级的方式对之进行处理,即在服务器宕机时直接返回默认数据。

    需要注意的是!缓存降级这种处理方案并不具备通用性,即并非所有程序/业务在遭遇缓存服务器宕机时都可以使用缓存降级来处理。这是因为缓存降级对程序/业务的影响是有损的,即其大概率会导致程序的运行结果错误。因此开发者在使用缓存降级前必须要先确保错误的运行结果造成的各方面影响是可控的,否则就会给自身/公司带来诸多麻烦。这其中的典型就是涉及到金钱的业务是绝对不能使用缓存降级的。
 
 

如何保证缓存与数据库双写时的数据一致性?


    保证数据一致性的通用方案是先写数据库再写缓存,因为数据只有在被持久化后才能为缓存的首次/再次构建提供可靠基础。而由于缓存具备多种构建方式的原因,数据在具体写入缓存时的行为也会有所变化。缓存通常由两种构建方式:一是在插入/更新时永久缓存;二是在查询时定时缓存。对于前者数据通常会在写入数据库后直接写入缓存,这是为了避免读线程对数据库的查询;而后者则会在数据写入数据库中后删除原缓存,从而令新缓存得以在查询时重新构建。

    需要注意的是!在不加锁的情况下,想要保证数据的强一致性是不可能的。但又因为“绝对完善”的加锁会对程序的性能造成严重损失,因此出于性能/开销/安全等多方面考量我们通常只追求数据的弱/最终一致性。
 
 

如何优化Redis大量数据的导入/导出?


  • 使用管道技术向/令Redis服务器一次性发送/执行多个指令,从而避免网络多次传输指令/数据所造成的性能损耗;
  • 向/令服务端发送/执行包含所有指令的Lua脚本,从而避免网络多次传输指令/数据的同时增强执行指令的执行效率。
     
     

如何找出Redis中指定前缀的所有键?


  • 使用{KEYS}指令进行同步查询,但可能阻塞Redis的内存读/写,因此不推荐;
  • 使用{SCAN}指令进行异步查询,不会阻塞Redis的内存读/写,推荐。但查询结果可能重复,因此需要视情况进行去重。
     
     

如何使用Redis实现队列?


  • 采用列表类型,并令生产者/消费者使用{RPUSH}/{LPOP/BLPOP}指令向尾部插入/从头部移除数据。{LPOP/BLPOP}指令用于实现移除的特殊值/阻塞形式;
  • 直接使用Redis的发布/订阅功能,但数据不会被持久化,因此消费者下线时数据会丢失。
     
     

如何使用Redis实现延时队列?


    使用有序集合类型,将数据的score @ 分数用来保存实际的可移除时间,并令消费者只移除已到移除时间的数据或先查看分数最小的数据是否可被移除。消息内容作为key,调用zadd来生产消息,消费者使用zrangbyscore获取n秒之前的数据做轮询处理。

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

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

相关文章

Flutter CustomScrollView 效果-顶栏透明与标签栏吸顶

CustomScrollView 效果 1. 关键组件 CustomScrollView, SliverOverlapAbsorber, SliverPersistentHeader 2. 关键内容 TLDR SliverOverlapAbsorber 包住 pinned为 true 的组件 可以被CustomScrollView 忽略高度。 以下的全部内容的都为了阐述上面这句话。初阶 Flutter 开发知…

Litctf-web

Litctf-web exx xxe&#xff0c; <?xml version"1.0" encoding"utf-8"?> <!DOCTYPE xxe [<!ELEMENT name ANY ><!ENTITY xxe SYSTEM "file:///flag" >]><user><username>&xxe;</username> …

线程模型介绍

线程模型的介绍 线程有三种模型&#xff1a;N:1用户线程模型&#xff0c;1:1核心线程模式&#xff0c;N:M混合线程模型 POSIX: Portable Operating System Interface(可移值操作系统接口) N&#xff1a;1用户线程模型 线程的实现建立在进程控制的机制之上&#xff0c;有用户…

2024 Rust现代实用教程:1.3获取rust的库国内源以及windows下的操作

文章目录 一、使用Cargo第三方库1.直接修改Cargo.toml2.使用cargo-edit插件3.设置国内源4.与windows下面的rust不同点 参考 一、使用Cargo第三方库 1.直接修改Cargo.toml rust语言的库&#xff1a;crate 黏贴至Cargo.toml 保存完毕之后&#xff0c;自动下载依赖 拷贝crat…

ML 系列:第 18 部 - 高级概率论:条件概率、随机变量和概率分布

文章目录 一、说明二、关于条件概率2.1 为什么我们说条件概率&#xff1f;2.2 为什么条件概率在统计学中很重要 三、 随机变量的定义3.1 定义3.2 条件概率中的随机变量 四、概率分布的定义五、结论 一、说明 条件概率是极其重要的概率概念&#xff0c;它是因果关系的数学表述&…

基于springboot的社区团购系统设计与实现

一、项目背景 网络交易&#xff08;Electronic Commerce&#xff09;&#xff1a;是指实现整个贸易过程中各阶段的贸易活动的电子化。网络交易是一种多技术的集合体。其业务可包括&#xff1a;信息交换、售后服务、销售、电子支付、运输、组建虚拟企业、公司和贸易伙伴可以共同…

挑战Java面试题复习第4天,坚持就是胜利

挑战第 4 天 Excption与Error包结构OOM 知识点SOF 知识点线程程序进程知识点有些字段不想序列化&#xff0c;怎么办&#xff1f;说说 IO 流Java IO与 NIO的区别 Excption与Error包结构 运行时异常&#xff08;RuntimeException&#xff09;&#xff1a; 包括RuntimeException…

一文读懂系列:SSL加密流量检测技术详解

SSL加密流量检测功能的主要目的是为了对加密流量做解密处理&#xff0c;并对解密后的流量做内容安全检查&#xff08;比如反病毒、入侵防御、URL远程查询、内容过滤、文件过滤和邮件过滤等&#xff09;和审计&#xff08;防止信息泄露&#xff09;。接下来我们详细介绍SSL加密流…

dependencyManagement保持maven的多模块依赖版本一致

在maven的多模块中, 为保持jar包在每个子模块中版本一致, 一般会有两种选择&#xff1a; 在父pom的dependencies标签中声明一个jar&#xff0c;每个子模块都会默认继承该jar 如果只有部分子模块用到了一个jar, 则会选择将该jar坐标信息声明在父pom的dependencyManagement标签中…

axis 参数的方向

axis0&#xff1a;表示沿着行的方向进行操作&#xff0c;即对每一列进行操作。 axis1&#xff1a;表示沿着列的方向进行操作&#xff0c;即对每一行进行操作。 示例&#xff1a; import numpy as np# 创建一个二维数组 array np.array([[1, 2, 3],[4, 5, 6],[7, 8, 9] ])axis0…

golang的循环引用解决方法

循环引用是指在数据结构中&#xff0c;两个或多个实体相互引用&#xff0c;形成一个闭环。例如&#xff0c;在 Golang 的结构体中&#xff0c;如果结构体 A 包含结构体 B 的实例&#xff0c;而结构体 B 又包含结构体 A 的实例&#xff0c;这种情况就称为循环引用。以下是关于循…

【C++】关联式容器

1.Set和Map 1.1 set的介绍 set是一个常用的关联式容器&#xff0c;它存储唯一的元素&#xff0c;这些元素默认情况下按照升序排序。其底层是一种自平衡的二叉搜索树(红黑树)。 set元素的键值就是实值&#xff0c;实值就是键值。set的元素允许插入删除但是不允许修改(具有const…

Spring Cloud Function快速入门Demo

1.什么是Spring Cloud Function&#xff1f; Spring Cloud Function是一个具有以下高级目标的项目&#xff1a; 通过功能促进业务逻辑的实现。将业务逻辑的开发生命周期与任何特定的运行时目标脱钩&#xff0c;以便可以将相同的代码作为Web终结点&#xff0c;流处理器或任务来…

第3章 继承与多态

Java面向对象程序设计-T3(继承与多态) 一、封装 1、概述 封装是指隐藏对象的属性和实现细节,仅对外提供公共访问方式。 public class Student {//1、私有化属性private String name;private int age;//2、提供公共方法供外部访问//传入数据public void setName(String nam…

荣誉证书PSD素材(59套免费)

本作品提供荣誉证书PSD素材下载&#xff0c;格式为PSD&#xff1b; 请使用软件Photoshop进行编辑&#xff0c;作品中文字及图均可以通过软件修改和编辑&#xff1b; 点击下载: 荣誉证书PSD素材

Java三大特性之多态

多态是Java的三大特性之一&#xff0c;它指的是同一个方法名字&#xff0c;在不同的对象中有不同的实现方式。具体来说&#xff0c;多态有两种表现形式&#xff1a;静态多态&#xff08;编译时多态&#xff0c;也称为重载&#xff09;和动态多态&#xff08;运行时多态&#xf…

第T6周:Tensorflow实现好莱坞明星识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 目标 具体实现 &#xff08;一&#xff09;环境 语言环境&#xff1a;Python 3.10 编 译 器: PyCharm 框 架: &#xff08;二&#xff09;具体步骤 1.查询…

Spring6框架搭建(自用)

一、什么是Spring 众所不周知&#xff0c;Spring就是爪哇人的春天&#xff0c;但是在框架程序设计之前都绕不开javaWeb 1.javaWeb框架发展史 1、ServletJSPJavaBean(跳转页面、业务逻辑判断、数据库查询) 2、MVC三层架构(M Model pojo(User)V-view(USP)C-(controller-servl…

linux-UART

参考博客 https://blog.csdn.net/m0_38106923/article/details/126024970?sharetypeblog&shareId126024970&sharereferAPP&sharesourceweixin_40933496&sharefromlink 1.串口 UART的全称是Universal Asynchronous Receiver and Transmitter&#xff0c;即异步…

大数据治理:策略、技术与挑战

随着信息技术的飞速发展&#xff0c;大数据已经成为现代企业运营和决策的重要基础。然而&#xff0c;大数据的复杂性、多样性和规模性给数据管理带来了前所未有的挑战。因此&#xff0c;大数据治理应运而生&#xff0c;成为确保数据质量、合规性、安全性和可用性的关键手段。本…