zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    Mysql高可用MHA
    centos7.2 安装mysql5.7.13
    keepalived+双主实现数据库的高可用
    xtrabackup 完全备份+xtrabacup 增量备份
    xtrabackup 进行 MySQL 数据库备份
    mysql所有备份与恢复
    sysbench压测工具 压测 mysql
    查看CPU性能参数(mpstat, iostat, sar、vmstat)等命令详解
    脚本
    解决 Let’s Encrypt SSL 证书配置错误
  • 原文地址:https://www.cnblogs.com/chengxuyuan-liu/p/10487946.html
Copyright © 2011-2022 走看看