广告
返回顶部
首页 > 资讯 > 数据库 >redis实现多级缓存同步方案详解
  • 555
分享到

redis实现多级缓存同步方案详解

redis多级缓存同步redis多级缓存redis缓存同步 2022-12-21 16:12:11 555人浏览 安东尼
摘要

目录前言多级缓存数据同步如何使用Redis6客户端缓存总结前言 前阵子参加业务部门的技术方案评审,故事的背景是这样:业务部门上线一个专为公司高管使用的系统。这个系统技术架构形如下图 按理来说这个系统因为受众很小,可以说

前言

前阵子参加业务部门的技术方案评审,故事的背景是这样:业务部门上线一个专为公司高管使用的系统。这个系统技术架构形如下图

redis实现多级缓存同步方案详解

按理来说这个系统因为受众很小,可以说基本上没并发,业务也没很复杂,但就是这么一个系统,连续2次出现数据库宕机,而导致系统无法正常运行。因为这几次事故,业务部门负责人组织这次技术方案评审,主题如何避免再次出现类似这种故障?

当时有个比较资深的技术,他提出当数据库出现宕机时,可以切换到redis,redis里面缓存热点数据,另外一个技术说他赞同这个方案,但他提出不需要用到redis,直接用本地缓存即可。因为Tomcat集群部署,就等于本地缓存也具备了集群能力。而如果切换成redis,redis也可能会挂现象。

然后那个说用redis的技术又说,用本地缓存,如果数据变更,其他集群的本地缓存如何感知数据已经发生变化,他觉得还是用redis靠谱,首先redis容量肯定是比本地缓存高,而且redis也可以部署集群,可用性可以得到保障,利用redis集中存储,当数据发生变更,其他集群也可以感知到。

在他们争论不休的情况下,有人提出不然就同时使用,当数据库挂了,切换到redis,redis挂了,使用本地缓存。这个方案得到不少人的同意,包括这两个争论不休的技术。但使用这种方案,就得考虑多级缓存数据如何同步。

铺垫了那么多,才刚要说今天的主题,多级缓存数据如何进行同步

多级缓存数据同步

1、方案一:使用MQ或者canal进行同步

方案如下图

redis实现多级缓存同步方案详解

如果是使用MQ来同步,实现方案大致如下,数据发生变更,业务系统发送变更数据到MQ,其他系统从MQ消费。

如果是使用canal,实现方案大致如下,数据发生变更,canal会接到到变更的binlog,业务系统编写canal tcp客户端,和canal进行交互获取变更数据

2、方案二:利用redis6提供的客户端缓存机制

方案如下图

redis实现多级缓存同步方案详解

redis6客户端缓存实现机制原理,官方有详细文档介绍,感兴趣大家可以查看如下链接
https://redis.io/docs/manual/client-side-caching/

这边就讲下如何使用

如何使用redis6客户端缓存

前置条件:redis服务端版本必须是>=6。lettuce版本>=6 目前Java的redis客户端找了一圈,貌似只有lettuce 6支持,其他客户端估计后期会支持

1、项目中pom引入lettuce GAV

  <dependency>
            <groupId>io.lettuce</groupId>
            <artifactId>lettuce-core</artifactId>
            <version>6.1.8.RELEASE</version>
        </dependency>

2、利用lettuce6提供的ClientSideCaching进行实现

    
    public String getClientCacheValue(Map<String,String> clientCache,String key){
        StatefulRedisConnection<String, String> connect = redisClient.connect();
      //  Map<String,String> clientCache = new ConcurrentHashMap<>();
        CacheFrontend<String,String> frontend = ClientSideCaching.enable(CacheAccessor.fORMap(clientCache),
                connect, TrackingArgs.Builder.enabled().noloop());
        return frontend.get(key);

    }

3、测试

    @Override
    public void run(ApplicationArguments args) throws Exception {
        while(true){
            System.out.println(lettuceRedisTemplate.getClientCacheValue("zhangsan"));
            TimeUnit.SECONDS.sleep(1);
        }


    }

redis里面的zhangsan数据未发生变更时,

redis实现多级缓存同步方案详解

控制台输出的数据为

redis实现多级缓存同步方案详解

我们将redis zhangsan的密码改成9999,

redis实现多级缓存同步方案详解

看本地缓存能否立马捕捉到

redis实现多级缓存同步方案详解

控制台发现密码已经改成9999

总结

由示例我们可以看出redis6提供了一个很好的多级缓存同步的实现方案。

我们再聊下那个技术评审的后续,后面业务部门并没有采用当Mysql宕机,使用redis作为兜底,也没采用本地缓存,更没采用两者结合的方案。

不知道大家开会的时候,有没有这样的体会,有时候我们在聊一个东西,后面聊着聊着就发散出去,把方向搞丢了。业务部门他们需要数据库宕机的解决方案吗,看着像是,其实他们更核心的需要,是业务系统不宕机。

奥卡姆剃刀定律:如无必要,勿增实体。其实不管加redis或者本地缓存,额外都增加系统维护成本。因为系统本身不复杂,加了缓存,就要额外考虑缓存数据一致性等

后面业务部门的处理方式,是将自己搭建的mysql,切换成云厂商的mysql。这样的好处是,云厂商的mysql会更稳定,其次当出现问题,可以找云厂商进行解决,毕竟云厂商的运维能力是比较强的,花钱买心安

这次事故会让业务部门那么重视,主要是使用方是高管,如果是一般使用者,挂就挂吧,大不了重启,使用对象不一样,应急处理方式就不一样

demo链接

Https://GitHub.com/lyb-geek/SpringBoot-learning/tree/master/springboot-localcache-redis-sync

到此这篇关于redis实现多级缓存同步的文章就介绍到这了,更多相关redis 多级缓存同步内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: redis实现多级缓存同步方案详解

本文链接: https://www.lsjlt.com/news/175467.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • redis实现多级缓存同步方案详解
    目录前言多级缓存数据同步如何使用Redis6客户端缓存总结前言 前阵子参加业务部门的技术方案评审,故事的背景是这样:业务部门上线一个专为公司高管使用的系统。这个系统技术架构形如下图 按理来说这个系统因为受众很小,可以说...
    99+
    2022-12-21
    redis多级缓存同步 redis多级缓存 redis缓存同步
  • 基于Java实现Redis多级缓存方案
    目录一、多级缓存1. 传统缓存方案2. 多级缓存方案二、JVM本地缓存1. 实用案例三、缓存一致性1. 常见方案1.1 设置有效期1.2 同步双写1.3 异步通知2. 基于Canal...
    99+
    2022-11-13
  • MySQL 与 Redis 缓存的同步方案
    MySQL 与 Redis 缓存的同步方案 概述 MySQL 和 Redis 都是常见的数据存储方案,MySQL 用于存储结构化数据,Redis 用于存储非结构化数据。在一些高并发场景下,为了提升系统...
    99+
    2023-09-14
    redis 缓存 mysql
  • Redis实现多级缓存
    本文实例为大家分享了Redis实现多级缓存的具体代码,供大家参考,具体内容如下 一、多级缓存 1. 传统缓存方案 请求到达tomcat后,先去redis中获取缓存,不命中则去mysql中获取 2. 多级缓存方案 tom...
    99+
    2022-07-28
    Redis 多级缓存
  • 浅谈MySQL与redis缓存的同步方案
    目录一、方案1(UDF)演示案例二、方案2(解析binlog)Canal开源技术三、附加本文介绍MySQL与Redis缓存的同步的两种方案 方案1:通过MySQL自动同步刷新R...
    99+
    2022-11-11
  • NestJS+Redis实现缓存步骤详解
    NestJS的缓存模块天生支持Redis等缓存机制。以下通过一个示例,说明如何在NestJS中操作Redis。步骤如下: 先安装运行Redis服务,步骤参见链接 新建nestjs项目...
    99+
    2022-11-12
  • redis如何实现多级缓存
                                 ...
    99+
    2022-10-18
  • Redis缓存实例分步详解
    目录一、简介1、场景2、RedisTemplate二、引入Redis1、项目中集成Redis2、添加Redis连接配置3、启动Redis服务三、测试RedisTemplate1、存值...
    99+
    2023-05-14
    Redis缓存策略 Redis缓存机制 Redis缓存
  • MySQL与redis缓存怎么实现同步
    MySQL与redis缓存怎么实现同步?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、方案1(UDF)场景分析:当我们对MySQL数据库进行数据操作时,同时将...
    99+
    2023-06-14
  • 基于Java怎么实现Redis多级缓存
    这篇文章主要介绍“基于Java怎么实现Redis多级缓存”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于Java怎么实现Redis多级缓存”文章能帮助大家解决问题。一、多级缓存1. 传统缓存方案请...
    99+
    2023-06-29
  • springboot+mybatis+redis 二级缓存问题实例详解
    前言什么是mybatis二级缓存?二级缓存是多个sqlsession共享的,其作用域是mapper的同一个namespace。即,在不同的sqlsession中,相同的namespace下,相同的sql语句,并且sql模板中参数也相同的,会...
    99+
    2023-05-30
    spring boot mybatis
  • MySQL数据和Redis缓存一致性方案详解
    读取缓存步骤一般没有什么问题,但是一旦涉及到数据更新:数据库和缓存更新,就容易出现 缓存(Redis)和数据库(MySQL)间的数据一致性问题。 不管是先写MySQL数据库,再删除Redis...
    99+
    2022-10-18
  • 浅谈SpringCache与redis集成实现缓存解决方案
    缓存可以说是加速服务响应速度的一种非常有效并且简单的方式。在缓存领域,有很多知名的框架,如EhCache 、Guava、HazelCast等。Redis作为key-value型数据库,由于他的这一特性,Redis也成为一种流行的数据缓存工具...
    99+
    2023-05-30
    spring cache redis
  • 详解SpringBoot2.0的@Cacheable(Redis)缓存失效时间解决方案
    问题   @Cacheable注解不支持配置过期时间,所有需要通过配置CacheManneg来配置默认的过期时间和针对每个类或者是方法进行缓存失效时间配置。 解决 ...
    99+
    2022-11-12
  • Springboot详解缓存redis实现定时过期方法
    目录前言添加依赖添加配置常规缓存开启缓存设置缓存空间设置缓存增加设置缓存过期时间总结后记前言 使用redis进行缓存数据,是目前比较常用的缓存解决方案。常用的缓存形式有一下几种: 1...
    99+
    2022-11-13
  • 利用Redis实现分布式缓存穿透解决方案
    利用Redis实现分布式缓存穿透解决方案随着互联网业务的不断发展,数据访问量也在不断增加,为了提高系统的性能和用户体验,缓存技术逐渐成为了必不可少的一部分,其中Redis作为一种高效、可扩展的缓存中间件方案,备受开发者的青睐。在使用Redi...
    99+
    2023-11-07
    redis 分布式缓存 缓存穿透
  • 利用Redis实现分布式缓存失效解决方案
    利用Redis实现分布式缓存失效解决方案,需要具体代码示例在分布式系统中,缓存是提高性能和减轻数据库负载的重要组成部分。而缓存的失效是一个常见的问题,当缓存中的数据发生变化时,我们需要及时将缓存失效,保证数据的一致性。Redis是一个高性能...
    99+
    2023-11-08
    分布式 redis 缓存失效
  • Redis百亿级Key存储方案怎么实现
    本篇内容主要讲解“Redis百亿级Key存储方案怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis百亿级Key存储方案怎么实现”吧!1.需求背景该...
    99+
    2022-10-19
  • 详解uniapp的缓冲实现方案
    【序】在移动App开发中,常常需要对数据进行缓存处理,以提升用户体验和节省网络流量消耗,而在uniapp开发中也可以通过一些方案来实现数据的缓存处理。本文将介绍uniapp的缓冲实现方案,从而帮助开发者优化应用的运行性能。【正文】一、uni...
    99+
    2023-05-14
  • 详解基于MybatisPlus两步实现多租户方案
    1.定义一个TenantLineHandler的实现类: import com.baomidou.mybatisplus.extension.plugins.handler.Te...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作