• Redis事务,持久化,缓存同步


    1、事务:Redis事务只能保证ACID中的隔离性和一致性,无法保证原子性和持久性。我们使用事务最重要是一条就是原子性,所以不建议使用Redis事务,所以需要事务的场景可以通过业务代码来实现

    https://www.jianshu.com/p/c9f5718e58f0

     2、持久化:RDB和AOF

    https://www.cnblogs.com/xingzc/p/5988080.html

    3、缓存同步

    持久层数据库和redis数据库同步方案,目前据我所知大都是通过自己写代码实现同步。同步方案有如下几种:

    方案一:通过canal+mysql实现同步,关于canal之前有说过,该方案的好处:实现了数据同步的代码和业务代码分离,以及利用canal自带的消息队列属性解决高并发下的数据同步问题。该方案缺点:只能持久层数据库只能支持mysql

    方案二:在更新持久层数据库时,同时更新redis(或更新持久数据库前删除reids缓存),在查询时,查询redis,如果redis没有数据,则将持久层数据查询出来,并同步到缓存。这样的方案会出现一个问题:当更新完持久层数据库后,紧接着更新redis时,redis宕机的话,则导致数据不一致,所以进一步解决方案有如下:先做好redis集群降低单机宕机概率,其次在更新redis的代码时,做好异常处理,发生异常后启动异步定时任务,定期检测redis服务,等redis重启后重新更新

    方案三:在方案二的基础上,可能会出现并发问题:所以想activmq这样的消息队列中间件则起到了作用(或自己写消息队列),在高并发的情况下利用activmq将请求队列化,然后redis一个个的将这些需要同步的数据进行处理

    canal+mysql实现缓存同步:

    https://blog.csdn.net/fcly2013/article/details/79430484

  • 相关阅读:
    寒假自学1.11
    寒假学习1.10
    寒假自学1.09
    寒假自学1.08-python的安装学习
    寒假1.08
    寒假自学1.07
    寒假自学1.06-tensorflow安装过程
    java & | 运算符
    java << >>
    java基础百位数十位数个位数
  • 原文地址:https://www.cnblogs.com/chengxuyuan-liu/p/10487946.html
Copyright © 2020-2023  润新知