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;信息交换、售后服务、销售、电子支付、运输、组建虚拟企业、公司和贸易伙伴可以共同…

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

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

【C++】关联式容器

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

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

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

第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;成为确保数据质量、合规性、安全性和可用性的关键手段。本…

vue插件清除 所有console.log()

一、作用 1、提升性能console.log() 语句会消耗一定的性能&#xff0c;尤其是在频繁调用的情况下。在生产环境中移除这些语句可以提高应用的运行效率。 2、减少信息泄露console.log() 可以输出敏感信息&#xff08;如用户数据、API 响应等&#xff09;。在生产环境中&#xf…

DAY15|二叉树Part03|LeetCode: 513.找树左下角的值、112. 路径总和、106. 从中序与后序遍历序列构造二叉树

LeetCode: 513.找树左下角的值 力扣代码链接 文字讲解&#xff1a;LeetCode: 513.找树左下角的值 视频讲解&#xff1a;怎么找二叉树的左下角&#xff1f; 递归中又带回溯了&#xff0c;怎么办&#xff1f; 基本思路 对题目进行一下分析&#xff0c;要找二叉树最底层最左边节点…

ClkLog企业版(CDP)预售开启,更有鸿蒙SDK前来助力

新版本发布 ClkLog在上线近1年后&#xff0c;获得了客户的一致肯定与好评&#xff0c;并收到了不少客户对功能需求的反馈。根据客户的反馈&#xff0c;我们在今年三季度对ClkLog的版本进行了重新的规划与调整&#xff0c;简化了原有的版本类型&#xff0c;方便客户进行选择。 与…

C++:set和map的使用

目录 序列式容器和关联式容器 set set类的介绍 构造和迭代器 增删查 insert find和erase erase迭代器失效 lower_bound与upper_bound multiset和set的区别 map map类的介绍 pair类型介绍 构造和迭代器 增删查 map数据修改&#xff1a;重载operator[] multimap…

Unix和Linux系统中的文件权限

详细解释Unix和Linux系统中的文件权限设置以及如何使用chmod命令来修改这些权限。 文件权限的详细解释 在Unix和Linux系统中&#xff0c;文件权限是控制谁可以访问和操作文件或目录的重要机制。权限分为三类&#xff1a;所有者&#xff08;owner&#xff09;、所属组&#xf…

android定时器循环实现轮播图

说明&#xff1a; android定时器加for循环实现轮播图 效果&#xff1a; step1: package com.example.iosdialogdemo;import android.os.Bundle; import android.os.Handler; import android.widget.ImageView; import android.widget.TextView;import androidx.appcompat.ap…

ChatGPT能预测时间序列?基于大模型的时间序列预测中的迭代事件推理_chatgpt能预测时间序列

引言 时间序列预测&#xff08;Time Series Forecasting&#xff09;是支撑经济、基础设施和社会各领域决策的关键技术。然而&#xff0c;传统的预测方法在面对由外部随机事件引起的突发性变化或异常时&#xff0c;往往表现出局限性。这些方法通常依赖于历史数据的模式识别&am…