19.缓存的认识和基本使用

缓存介绍

缓存是数据交换的缓冲区Cache,是临时存储数据的地方,一般读写性能较高。

数据库的缓存就是建立索引。

缓存的作用

1.降低后端负载。

2.提高读写效率,降低响应时间。

缓存的问题

1.保证数据的一致性。

2.增加代码维护成本。解决一些常见的缓存问题。

3.增加运维成本,会搭建一些缓存的集群部署。

String类型

java 复制代码
 @Autowired
    private StringRedisTemplate stringRedisTemplate;

 @Override
    public Result queryById(Long id) {
        String key = RedisConstants.CACHE_SHOP_KEY + id;
        //从redis中查询商铺缓存
        String shopJsonStr = stringRedisTemplate.opsForValue().get(key);
        //redis中有数据直接返回
        if(StrUtil.isNotBlank(shopJsonStr)) {
            Shop shop = JSONUtil.toBean(shopJsonStr, Shop.class);
            return Result.ok(shop);
        }
        //redis中没有数据,继续查询数据库
        Shop shop = getById(id);
        if(ObjectUtil.isNull(shop)) {
            //数据库没有查询到数据,返回错误
            return Result.fail("店铺不存在");
        }
        //数据库中查询到数据,存入redis,再返回数据
        stringRedisTemplate.opsForValue().set(key, JSONUtil.toJsonStr(shop));
        return Result.ok(shop);
    }

List类型

java 复制代码
@Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Override
    public Result queryTypeList() {

        String key = "cache:shopType:all";

        List<String> shopTypeList = stringRedisTemplate.opsForList().range(key, 0, -1);
        if(CollectionUtil.isNotEmpty(shopTypeList)) {
            List<ShopType> shopTypes = new ArrayList<>();
            shopTypeList.stream().forEach(e -> {
                ShopType shopType = JSONUtil.toBean(e, ShopType.class);
                shopTypes.add(shopType);
            });
            return Result.ok(shopTypes);
        }

        List<ShopType> shopTypes = query().orderByAsc("sort").list();
        if(CollectionUtil.isEmpty(shopTypes)) {
            return Result.ok("没有找到店铺类型");
        }

        shopTypes.stream().forEach(e -> shopTypeList.add(JSONUtil.toJsonStr(e)));
        stringRedisTemplate.opsForList().rightPushAll(key, shopTypeList);
        return Result.ok(shopTypes);
    }
相关推荐
.Shu.29 分钟前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
lssjzmn9 小时前
🚀如何基于Redis的ZSet数据结构设计一个通用的,简单的,可靠的延迟消息队列,以RedisTemplate为例
redis
jakeswang10 小时前
应用缓存不止是Redis!——亿级流量系统架构设计系列
redis·分布式·后端·缓存
.Shu.12 小时前
Redis zset 渐进式rehash 实现原理、触发条件、执行流程以及数据一致性保障机制【分步源码解析】
数据库·redis·缓存
君不见,青丝成雪12 小时前
大数据技术栈 —— Redis与Kafka
数据库·redis·kafka
悟能不能悟12 小时前
排查Redis数据倾斜引发的性能瓶颈
java·数据库·redis
切糕师学AI12 小时前
.net core web程序如何设置redis预热?
redis·.netcore
Mi_Manchikkk13 小时前
Java高级面试实战:Spring Boot微服务与Redis缓存整合案例解析
java·spring boot·redis·缓存·微服务·面试
xiao-xiang13 小时前
redis-集成prometheus监控(k8s)
数据库·redis·kubernetes·k8s·grafana·prometheus
TT哇1 天前
@[TOC](计算机是如何⼯作的) JavaEE==网站开发
java·redis·java-ee