缓存学习实战篇

缓存练习题(用户查询操作)

java 复制代码
    public List<ShopType> queryAllType() throws JsonProcessingException {
        //从缓存中查数据
        String shopTypeJson = stringRedisTemplate.opsForValue().get("cache:shopType");
        //如果缓存命中,
        if (StrUtil.isNotBlank(shopTypeJson)) {
            return new ObjectMapper().readValue(shopTypeJson, new TypeReference<List<ShopType>>() {
            });
        }
        //如果缓存不命中,查数据库
        List<ShopType> shopTypeList = shopTypeMapper.selectList(null).stream().sorted(Comparator.comparingInt(ShopType::getSort))
                .collect(Collectors.toList());
        if (shopTypeList == null) {
            return null;
        } else {
            stringRedisTemplate.opsForValue().set("cache:shopType", new ObjectMapper().writeValueAsString(shopTypeList));
        }
        //如果过数据库不命中,则返回错误
        //如果过数据库命中,则更新缓存
        return null;
    }

缓存更新策略(更新商品操作)

缓存操作很快,操作数据库很慢

方案1:如果先删除缓存,再操作数据库,线程1 ,清空缓存,线程2 查询缓存未命中,写入数据库数据是10,此时线程1,数据库更新

方案2:缓存因为某种原因失效了 ,线程1缓存未命中查出数据库10,另外一个线程2更新数据库,删除缓存,写缓存时数据为20,但是这种情况基本不存在

结论:由于缓存速度很快,所以第二种情况发生概率很低,采用先操作数据库,再删除缓存

bash 复制代码
    @Override
    @Transactional
    public Result update(Shop shop) {
        if (shop.getId() == null) {
            return Result.fail("500");
        }
        //1、更新数据库
        updateById(shop);
        //2、删除缓存
        stringRedisTemplate.delete(CACHE_SHOP_KEY + shop.getId());
        return Result.ok();
    }

缓存穿透

缓存空对象

空的值缓存到Redis

优点:实现简单,维护方便

缺点:额外的内存消耗;造成短期的不一致(如果此时数据库真的增加了,在TTL过期以后才能查询到真数据)

设置TTL,比如5分钟,方式恶意用户访问

布隆过滤

优点:内存占用较少,没有多余key

缺点:存在误判可能

相关推荐
知识分享小能手4 小时前
React学习教程,从入门到精通, React 属性(Props)语法知识点与案例详解(14)
前端·javascript·vue.js·学习·react.js·vue·react
luckys.one4 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
言之。5 小时前
Django中的软删除
数据库·django·sqlite
茯苓gao6 小时前
STM32G4 速度环开环,电流环闭环 IF模式建模
笔记·stm32·单片机·嵌入式硬件·学习
是誰萆微了承諾7 小时前
【golang学习笔记 gin 】1.2 redis 的使用
笔记·学习·golang
阿里嘎多哈基米7 小时前
SQL 层面行转列
数据库·sql·状态模式·mapper·行转列
抠脚学代码7 小时前
Ubuntu Qt x64平台搭建 arm64 编译套件
数据库·qt·ubuntu
jakeswang7 小时前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
DKPT7 小时前
Java内存区域与内存溢出
java·开发语言·jvm·笔记·学习
aaaweiaaaaaa7 小时前
HTML和CSS学习
前端·css·学习·html