【Redis】缓存穿透

问题发生背景:客户端请求的数据再缓存中和数据库中都不存在。
导致的问题:缓存永远不会生效,这些请求都会去请求数据库—导致数据库压力增大。
解决方案:
1.缓存空对象
在Redis中缓存空对象,告诉客户端数据库中没有该值。 该方法得设置一个短时间的TTL。
优点:实现简单,维护方便
缺点:会有额外的内存消耗,可能造成短期的不一致。 —数据库更新的时候,缓存还没变。
在这里插入图片描述
2.布隆过滤:
在这里插入图片描述
总体思路如上图所示,就是在客户端取数据的时候先访问布隆过滤器,得到数据库是否包含该数据的结果,有再访问没有就不访问。
布隆过滤器原理:
其实这就是一个哈希算法,哈希查询算法,
哈希算法是借助哈希表查找目标元素的方法,其中用的是哈希函数。
key = f(value)。f()是哈希函数,得到的结果是目标元素的key。
而在布隆过滤器这里,我们不需要知道目标元素的key,我们只需要知道这个元素存不存在,所以,我们的散列函数里面存储的就是0和1,0表示不存在,1表示存在。
而布隆过滤器的实现:

  1. 建立一个二进制向量,将所有位设置为0.
  2. 选定k个散列函数,用于对元素进行k次散列,计算向量的位下标。
  3. 添加元素,每添加一个就用k个散列函数分别作用于元素,生成对应下标,并将对应的值设为1.
  4. 检查元素,检查一遍是否都是1。

在这里插入图片描述

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

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

相关文章

uni-app攻略:如何对接驰腾打印机

一.引言 在当前的移动开发生态中,跨平台框架如uni-app因其高效、灵活的特点受到了开发者们的青睐。同时,随着物联网技术的飞速发展,智能打印设备已成为许多业务场景中不可或缺的一环。今天,我们就来探讨如何使用uni-app轻松对接驰…

Codeforces Round 935 (Div. 3)A~E

A. Setting up Camp 题目分析: 有三种人,内向、外向、综合,内向必须独自一个帐篷,外向必须3个人一个帐篷,综合介于1~3人一个帐篷,我们发现非法情况只会存在外向的人凑不成3个人一个帐篷的情况,因外向不够可…

软件管理rpm与yum

源代码包下载 Compare, Download & Develop Open Source & Business Software - SourceForgehttps://sourceforge.net/ rpm包下载 Welcome to the RPM repository on fr2.rpmfind.nethttp://rpmfind.net/linux/RPM/ 软件包管理 1.rpm包管理: 1)查询: 安装…

微隔离有哪些作用

当前,在零信任安全渐渐被大家熟知的情况下,很多用户在网络安全方面有了更深的认知。在网络安全领域,许多企业用户认为零信任对于降低网络安全风险至关重要,有助于在复杂的网络环境中保护自身企业资源免受未经授权的访问和潜在的网…

掌握Go语言:Go语言结构体,精准封装数据,高效管理实体对象(22)

在Go语言中,结构体(Struct)是一种自定义的数据类型,用于封装不同类型的数据字段。结构体可以看作是一种用户自定义的数据结构,用于组织和管理相关的数据。结构体由一组字段(Fields)组成&#xf…

HDFSRPC安全认证Token篇

本文主要阐述HDFSRPC安全认证相关的实现。主要介绍Token相关的实现。 写在前面 相关blog https://blog.csdn.net/hncscwc/article/details/124722784 https://blog.csdn.net/hncscwc/article/details/124958357 Token由来 在探究完Kerberos,我一直在想一个问题…

docker基础(六)之docker create和docker exec

文章目录 概述docker create语法实例 docker exec语法示例 docker run、docker exec 和 docker create比较docker rundocker execdocker create 总结 概述 用于学习和记录,以下内容来自chatgpt3.5,网络等,补充例子。 本文介绍了docker create,docker e…

python基本概念和基本数据类型

一、基本概念 1.变量 变量是编程语言中最基本的概念,和字面意思一样,指的就是他们的值可变,和我们以前学习的方程类似,变量可以代入任何值。 命名规范:变量一般使用: 英文字母、下划线 和 数字组成 2.关键…

3.21 day2 QT

自由发挥登录窗口的应用场景,实现一个登录窗口界面 要求: 1.需要使用Ui界面文件进行界面设计 2.ui界面上的组件相关设置,通过代码实现 3需要添加适当的动图

模拟堆(详解+例题)

一、定义 维护一个数据集合,堆是一个完全二叉树。 那么什么是二叉树呢? 如图: 二、关于小根堆实现 性质:每个根节点都小于等于左右两边,所以树根为最小值。 2.1、堆存储(用一维数组来存) 记住…

基于范围的for循环(C++11)

c11的语法需要新的编译器,vs2018编译不了 ,linux也是要gcc g 4.6以上。基于范围的for需要新一点的编译器才能编译通过。 (1)范围for的语法 在C98中如果要遍历一个数组,可以按照以下方式进行: void TestFor…

数据分析面试题(1~10)

1、XGBoost原理介绍一下? ①首先,XGBoost是集成算法之一,它用多个弱学习器去生成一个强学习器。XGBoost基于梯度提升框架实现,沿着梯度负方向更新模型参数,使损失函数达到最小化。(梯度提升框架&#xff0…

docker各种命令的详细解释

Docker 是一个开源的容器化平台,它可以帮助开发人员打包、发布和运行应用程序。以下是 Docker 中常用的一些命令: docker run: 用于创建并运行一个容器。docker build: 用于基于 Dockerfile 构建一个容器镜像。docker pull: 用于从 Docker 镜像仓库中拉…

GifGun2汉化版点击渲染失败,弹窗提示“lossless不是有效的模板名称”

总算解决了,记录一下方法: 1)在AE顶部导航,点击“编辑 > 模板 > 输出模块” 2)新建一个名为GifGun的输出模块,为后续GifGun引用做准备。(取名随意) 3)在AE顶部导航…

软件测试教程 自动化测试之Junit框架

文章目录 1. 什么是 Junit ?2. 常见的注解2.1 Test2.2 BeforeAll,AfterAll2.3 BeforeEach,AfterEach 3. 测试用例顺序指定4. 参数化4.1 单个参数4.2 多个参数4.3 通过方法生成 5. 测试套件6. 断言6.1 断言相等6.2 断言不相等6.3 断言为空6.4 …

山东省大数据局副局长禹金涛一行莅临聚合数据走访调研

3月19日,山东省大数据局党组成员、副局长禹金涛莅临聚合数据展开考察调研。山东省大数据局数据应用管理与安全处处长杨峰,副处长都海明参加调研,苏州市大数据局副局长汤晶陪同。聚合数据董事长左磊等人接待来访。 调研组一行参观了聚合数据展…

软件设计师笔记

计算机 运算器组成:算术逻辑单元(ALU)、累加寄存器(AC)、数据缓冲寄存器(DR)、状态条件寄存器()等组成。 控制器组成:指令寄存器(IR)、程序计数器(PC)、地址寄存器(AR)、指令译码器(ID)。 最小数据单位:bit 最小存储单位: byte n进制 转 1…

蓝桥杯单片机备战——关于573问题的填坑

一、遇到的问题 还记得我前面在封装继电器外设的时候遇到的这个问题嘛,当时我怀疑的是138译码器在切换通道的时候会出现其他暂态导致已经锁定的573解锁。 其实不然,之所以会这样还是因为代码问题,也可以说是573反应时间太快了。下面我就分析…

SpringBoot自定义starter开发:使用属性配置设置功能参数

🙈作者简介:练习时长两年半的Java up主 🙉个人主页:程序员老茶 🙊 ps:点赞👍是免费的,却可以让写博客的作者开心好久好久😎 📚系列专栏:Java全栈,计算机系列(火速更新中) 💭 格言:种一棵树最好的时间是十年前,其次是现在 🏡动动小手,点个关注不迷路,…

麒麟系统中使用nginx发布项目

1. 安装Nginx sudo apt-get update #进行所有安装操作前都要执行这一句 sudo apt install nginx #出现询问就Yes参考具体 Nginx—在linux的ubuntu系统上的安装使用 2. 修改发布文件 将打包好的dist文件夹中的所有文件覆盖下面这个文件夹中的所有文件 如果出现没有权限替…