redis穿透解决方案

2024-06-18 12:30
文章标签 解决方案 redis 穿透

本文主要是介绍redis穿透解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Redis缓存穿透是指查询一个不存在于数据库中的数据(通常是恶意用户发起的连续请求),由于缓存中没有,每次请求都会穿透到数据库,这可能会对数据库造成不必要的压力。解决缓存穿透问题的常见策略包括:
       1.  布隆过滤器:用于判断一个元素是否可能存在于集合中,即使它返回存在,也可能是个假阳性(误报),但不会出现假阴性(即如果布隆过滤器说不存在,则该元素一定不存在)。因此,可以在查询数据库之前先检查布隆过滤器。

       2.  空值缓存:即使数据库中没有找到对应记录,也将空值(如null)写入缓存,并设置一个较短的有效期。这样,后续相同请求在缓存有效期内可以直接从缓存中得到结果,而不需要再次访问数据库。

       3. 设置黑白名单:通过白名单使需要的请求访问,通过黑名单防止攻击。

首先,确保你的项目中包含了Spring Data Redis和Guava的依赖。

布隆过滤器配置

import com.google.common.hash.Funnel;
import com.google.common.hash.Hashing;
import com.google.common.math.LongMath;
import com.google.common.primitives.Chars;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** 布隆过滤器配置类,用于初始化布隆过滤器的实例及其相关组件。*/
@Configuration
public class BloomFilterConfig {/*** 创建字符串处理的Funnel,用于将字符串转换为哈希输入。* * @return 字符串Funnel实例*/@Beanpublic Funnel<String> stringFunnel() {return (from, into) -> Chars.forEachUtf8(from, c -> into.putChar(c));}/*** 初始化布隆过滤器,基于预期插入数量和误报率进行配置。* * @param funnel 字符串处理的Funnel* @return 布隆过滤器实例*/@Beanpublic BloomFilter<String> bloomFilter(Funnel<String> funnel) {int expectedInsertions = 100000; // 预计需要插入过滤器的元素数量double fpp = 0.01; // 可接受的误报率,即预测为存在但实际上不存在的概率// 计算所需的哈希函数数量int numHashFunctions = LongMath.log2(LongMath.pow(2, Long.SIZE) / expectedInsertions * fpp);// 创建布隆过滤器实例return BloomFilter.create(funnel, expectedInsertions, fpp, Hashing.murmur3_128());}
}

缓存服务实现

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;/*** 缓存服务实现类,负责处理数据的缓存逻辑,包括使用布隆过滤器和空值缓存策略防止缓存穿透。*/
@Service
public class CacheService {private final StringRedisTemplate redisTemplate;private final BloomFilter<String> bloomFilter;/*** 构造函数注入Redis模板和布隆过滤器实例。** @param redisTemplate Redis操作模板* @param bloomFilter 布隆过滤器实例*/@Autowiredpublic CacheService(StringRedisTemplate redisTemplate, BloomFilter<String> bloomFilter) {this.redisTemplate = redisTemplate;this.bloomFilter = bloomFilter;}/*** 获取数据的方法,首先检查布隆过滤器,然后尝试从Redis缓存中获取,* 若缓存未命中且布隆过滤器认为可能存在,则查询数据库,并实施空值缓存策略。** @param key 数据的唯一标识* @return 查询到的数据或空值、提示信息*/public String getData(String key) {// 使用布隆过滤器快速判断key是否可能存在,减少不必要的数据库查询if (!bloomFilter.mightContain(key)) {return "This key is likely not in the database.";}// 尝试从Redis缓存中获取数据String value = redisTemplate.opsForValue().get(key);// 如果缓存未命中,且布隆过滤器判断可能在数据库中,则查询数据库if (value == null) {value = databaseFetch(key);// 数据库中也不存在,则将空值写入缓存,设置较短过期时间以避免长时间占用缓存if (value == null) {redisTemplate.opsForValue().set(key, "", 5, TimeUnit.MINUTES);} else {// 数据库中存在,则正常缓存该值redisTemplate.opsForValue().set(key, value);}}return value;}/*** 模拟从数据库获取数据的方法,实际应用中应替换为真实的数据库访问逻辑。** @param key 数据查询键* @return 从数据库查询到的数据或null*/private String databaseFetch(String key) {// 示例中始终返回null,表示数据库中也没有该数据return null;}
}

这篇关于redis穿透解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1072005

相关文章

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

Redis 命令详解与实战案例

《Redis命令详解与实战案例》本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统... 目录Redis 命令详解与实战案例一、Redis 基础介绍二、Redis 核心数据结构与命令1. 字符

Apache服务器IP自动跳转域名的问题及解决方案

《Apache服务器IP自动跳转域名的问题及解决方案》本教程将详细介绍如何通过Apache虚拟主机配置实现这一功能,并解决常见问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录​​问题背景​​解决方案​​方法 1:修改 httpd-vhosts.conf(推荐)​​步骤

SpringBoot18 redis的配置方法

《SpringBoot18redis的配置方法》本文介绍在SpringBoot项目中集成和使用Redis的方法,包括添加依赖、配置文件、自定义序列化方式、使用方式、实际使用示例、常见操作总结以及注意... 目录一、Spring Boot 中使用 Redis1. 添加依赖2. 配置文件3. Redis 配置类

Linux(centos7)虚拟机没有IP问题及解决方案

《Linux(centos7)虚拟机没有IP问题及解决方案》文章介绍了在CentOS7中配置虚拟机网络并使用Xshell连接虚拟机的步骤,首先,检查并配置网卡ens33的ONBOOT属性为yes,然后... 目录输入查看ZFhrxIP命令:ip addr查看,没有虚拟机IP修改ens33配置文件重启网络Xh

Java编译错误java.lang.NoSuchFieldError的解决方案详析

《Java编译错误java.lang.NoSuchFieldError的解决方案详析》java.lang.NoSuchFieldError是Java中的一种运行时错误,:本文主要介绍Java编译错... 目录前言解决方案1. 统一JDK版本环境2. 优化maven-compiler-plugin配置3. 清

Redis中群集三种模式的实现

《Redis中群集三种模式的实现》Redis群集有三种模式,分别是主从同步/复制、哨兵模式、Cluster,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1. Redis三种模式概述2、Redis 主从复制2.1 主从复制的作用2.2 主从复制流程2

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

Docker + Redis 部署集群的实现步骤

《Docker+Redis部署集群的实现步骤》本文详细介绍了在三台服务器上部署高可用Redis集群的完整流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、环境准备1. 服务器规划(3 台服务器)2. 防火墙配置(三台服务器均执行)3. 安装 docke