缓存学习实战篇

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

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

缺点:存在误判可能

相关推荐
sinat_3834373612 小时前
如何为表名加上图标前缀_根据表前缀自动匹配图标
jvm·数据库·python
SelectDB12 小时前
AI Agent 场景下,万级 JSON 字段的性能挑战与优化实践
数据库·人工智能·数据分析
毋语天12 小时前
从零开始:Docker 部署 Milvus 向量数据库并接入 Attu 与 pymilvus 的全流程指南
数据库·milvus
wang3zc12 小时前
如何在 Go 中为权威 DNS 服务器实现持久化域名记录存储
jvm·数据库·python
duke86926721412 小时前
如何在Bootstrap中实现响应式的统计数据卡片
jvm·数据库·python
2401_8463395612 小时前
如何优化SQL存储过程复杂排序_减少内存压力与重排操作
jvm·数据库·python
PawSQL12 小时前
同一条SQL,单机秒回,分布式集群卡成PPT——问题究竟出在哪?
数据库·分布式·sql
ㄟ留恋さ寂寞12 小时前
PHP怎么实现SAML单点登录_PHP企业级SSO解决方案【指南】
jvm·数据库·python
phltxy13 小时前
Seata 2.2.0:下载、部署与 Nacos + MySQL 集成教程
数据库·mysql·spring cloud·微服务
努力努力再努力wz13 小时前
【Qt 入门系列】从应用场景到开发环境:建立对 Qt 的第一层认知
c语言·开发语言·数据库·c++·b树·qt·缓存