Redis:处理缓存穿透的两种方法

缓存穿透:客户端请求的数据在缓存和数据库中都不存在,这样缓存永远不能生效,请求都会直接发送到数据库

解决方案:

1.缓存空对象

查完数据库后,将该数据以空值缓存进redis中,同时增加命中时对命中空值的判断

java 复制代码
 @Override
    public Result queryById(Long id) {
        String key=CACHE_SHOP_KEY+id;
        //1.从redis查询商铺缓存
        String shopJson=stringRedisTemplate.opsForValue().get(key);
        //2.判断是否存在,isNotBlank("")也为false
        if(StrUtil.isNotBlank(shopJson)){
            //3.存在,返回商铺对象
            Shop shop= JSONUtil.toBean(shopJson,Shop.class);
            return Result.ok(shop);
        }
        //判断命中的是否为空值
        if(shopJson != null && shopJson.isEmpty()){
            return Result.fail("店铺不存在");
        }
        //4.不存在,从mysql数据库中查询
        Shop shop=getById(id);
        //5.判断是否存在
        if(shop==null){
            //缓存空值,处理缓存穿透
            stringRedisTemplate.opsForValue().set(key,"",CACHE_NULL_TTL,TimeUnit.MINUTES);
            return Result.fail("店铺不存在");
        }
        //6.存在,向redis中缓存店铺数据

        stringRedisTemplate.opsForValue().set(key,JSONUtil.toJsonStr(shop),LOGIN_USER_TTL, TimeUnit.MINUTES);
        //7.返回
        return Result.ok(shop);
    }

2.布隆过滤器

3.增加id的复杂度,防止id规律被猜中

4.做好数据的基础格式校验

5.加强用户权限限制

相关推荐
恼书:-(空寄5 小时前
Redisson 原理与最佳实践
redis·分布式锁·redisson
gQ85v10Db8 小时前
Redis分布式锁进阶第十七篇:微服务分布式锁全局治理 + 跨团队统一规范落地 + 全链路稳定性提升方案
redis·分布式·微服务
Javatutouhouduan9 小时前
Java小白如何快速玩转Redis?
java·数据库·redis·分布式锁·java面试·后端开发·java程序员
Lyyaoo.10 小时前
Redisson
数据库·缓存
倒霉蛋小马12 小时前
【Redis】什么是缓存击穿?
数据库·redis·缓存
傻瓜搬砖人14 小时前
SpringBoot整合Junit-Redis-打包
spring boot·redis·junit
014-code14 小时前
布隆过滤器:判断“可能存在“和“一定不存在“
java·redis
gQ85v10Db15 小时前
Redis分布式锁进阶第十八篇:本地缓存+分布式锁双锁架构 + 高并发削峰兜底 + 极致性能无损优化实战
redis·分布式·缓存
小江的记录本15 小时前
【Kafka核心】Kafka高性能的四大核心支柱:零拷贝、批量发送、页缓存、压缩
java·数据库·分布式·后端·缓存·kafka·rabbitmq
gQ85v10Db15 小时前
Redis分布式锁进阶第十四篇:全系列终局架构复盘 + 锁体系统一规范 + 线上全年零事故收官方案
redis·分布式·架构