美文网首页
使用redis的感受

使用redis的感受

作者: 得鹿梦为鱼 | 来源:发表于2019-03-28 22:42 被阅读0次

想用redis

用户管理系统,编码完成了(包含用户、组织等等功能),但是查询用户列表、组织列表时,发现响应速度比较慢,所以打算使用redis来加快响应速度

开始行动

在用户列表(findAll),查询单个用户(findById,findByName)等方法上加了缓存,删除、修改等操作删除缓存

问题

不加思索的添加缓存,导致了一个严重的问题。耦合性非常严重

原因

用户管理,有分配组织的功能,也就是说,查询用户列表或者用户详情时,需要查询用户具有的组织信息;同理:也可以向组织添加用户

那么如果对用户列表添加了缓存,如果修改/删除了组织,没有清楚用户管理的缓存,那么用户列表返回的,还是组织未删除/修改前的数据,这就造成脏数据了,不是我们想要的

如果在删除/修改时,清除用户管理的缓存,这样可以实现用户列表数据的实时性,但问题就是:耦合性

组织删除/修改时,为什么要 用户的数据呢? 那要是下次再来一个角色管理,岂不是,在删除/修改角色信息时,又得清除 用户的缓存信息,这是非常严重的耦合问题

所以,决定去掉列表类接口的缓存

改进

既然去掉了列表类接口的缓存,剩下使用场景最多的,也就是查询单个对象了

又有问题

单个对象的查找,主要的作用还是在于,校验这个对象是否存在,无论是修改,删除、停/启用等等,首先都会校验用户是否存在

但是,这种查询,通常都是类内部直接调用,无法被缓存代理控制
原因:缓存注解(@Cacheable )由AOP 实现,类内部的方法调用类内部的加了缓存注解的方法,并没有通过AOP,因此缓存无法实现

这么看来,要使用缓存,就没有什么意义了

最终,决定去掉缓存
从代码层面进行优化,加快查询速度

Springboot 集成的缓存、事物等控制
都是通过AOP来进行处理的,当类内部的方法调用类内部的方法,缓存,事物都是不会生效的,所以,使用Springboot带给我们方便的同时,也要仔细思考,这些注解为什么能够生效,在哪些场合使用才是对的

BTW

现工程也有一个地方使用了redis
OAuth2.0 认证(客户端模式),通过key和secret获取token,是存在redis,因为redis里的数据可以根据配置的时间自动失效,比放数据库和内存中都方便

相关文章

  • 使用redis的感受

    想用redis 用户管理系统,编码完成了(包含用户、组织等等功能),但是查询用户列表、组织列表时,发现响应速度比较...

  • 干货!带你了解为什么那么多开源项目都是用Redis!

    很多开源项目中都使用了redis,这些项目为什么使用redis?使用redis有什么好处?怎么使用redis?带着...

  • Redis 初次见面

    目录 Redis 特性 使用场景 初次使用安装(Linux)配置启动 redis 的 3 种方法使用 redis ...

  • Redis一致性hash算法

    一、Redis集群的使用 我们在使用Redis的时候,为了保证Redis的高可用,提高Redis的读写性能,最简单...

  • Spring Cache与Redis结合使用

    Spring Cache与Redis结合使用 Spring Cache与Redis结合使用Redis创建Sprin...

  • redis学习历程

    Redis初识 Redis安装与启动 Redis 常用API 理解与使用 Redis java客户端使用(单机版,...

  • Spring Data Redis - Redis Reposi

    使用Redis Repositories可以方便的在redis中用Redis Hash的方式存储各种对象类型。使用...

  • redis 使用历程

    redis 使用历程 为什么使用redis缓存? 答:之前是没有使用redis的,直接用Java代码写类缓存功能,...

  • Redis中调用Lua脚本阻塞

    在高并发系统中,redis的使用会比较频繁,lua脚本让redis的使用更加灵活。redis中使用lua脚本的好处...

  • redis 集群搭建

    Redis集群 使用redis做缓存工具 实现系统高可用,redis需要做主备。使用redis做分片集群。 向业务...

网友评论

      本文标题:使用redis的感受

      本文链接:https://www.haomeiwen.com/subject/qfbxbqtx.html