美文网首页
使用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的感受

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