【聊透SpringMVC】java技术经理岗位职责

缓存维护方案一

如果是一读(线程B)一写(线程A)操作,「先操作缓存,再操作数据库」。流程图如下所示:

  • 1.线程A发起一个写操作,第一步del cache

  • 2.线程A第二步写入新数据到DB

  • 3.线程B发起一个读操作,cache miss缓存失效了。

  • 4.线程B从DB获取最新数据

  • 5.线程B执行set cache,把从DB读到的数据,更新到缓存。

「这样看,没啥问题」。我们再看第二个流程图,如下:

  • 1.线程A发起一个写操作,第一步del cache

  • 2.此时线程B发起一个读操作,cache miss

  • 3.线程B继续读DB,读出来一个老数据

  • 4.然后老数据设置入cache

  • 5.线程A写入DB最新的数据

OK,酱紫,就有问题了吧,老数据入到缓存了,「每次读都是老数据啦,缓存与数据与数据库数据不一致了」

缓存维护方案二

上个方案是一读一写,如果是双写操作,「先操作缓存,再操作数据库」,会怎么样呢?

  • 1.线程A发起一个写操作,第一步set cache

  • 2.线程A第二步写入新数据到DB

  • 3.线程B发起一个写操作,set cache

  • 4.线程B第二步写入新数据到DB

「这样看,也没啥问题。」,但是有时候可能事与愿违,我们再看第二个流程图,如下:

  • 1.线程A发起一个写操作,第一步set cache

  • 2.线程B发起一个写操作,第一步set cache

  • 3.线程B写入数据库到DB

  • 4.线程A写入数据库到DB

执行完后,缓存保存的是B操作后的数据,数据库是A操作后的数据,「缓存和数据库数据不一致」

缓存维护方案三

一写(线程A)一读(线程B)操作,「先操作数据库,再操作缓存」

  • 1.线程A发起一个写操作,第一步write DB

  • 2.线程A第二步del cache

  • 3.线程B发起一个读操作,cache miss

  • 4.线程B从DB获取最新数据

  • 5.线程B同时set cache

「有些朋友可能认为,在第2步删除缓存之前,线程B读过来呢?这时候,读到的是缓存老数据,这个可以认为是正常业务逻辑呀,下次再读取就是正确数据了。」

这种方案**「没有明显的并发问题」,但是有可能「步骤二删除缓存失败」,虽然概率比较小,「优于方案一和方案二」**,平时工作中也是使用方案三。

综上对比,我们一般采用方案三,但是有没有完美全解决方案三的弊端的方法呢?

缓存维护方案四

这个是方案三的改进方案,都是先操作数据库再操作缓存,我们来看一下流程图:

通过数据库的**「binlog」「异步淘汰key」,以mysql为例 可以「使用阿里的canal将binlog日志采集发送到MQ队列」里面,然后「通过ACK机制 确认处理」** 这条更新消息,删除缓存,保证数据缓存一致性。

但是呢还有个问题,「如果是主从数据库呢」

缓存维护方案五

主从DB问题:因为主从DB同步存在延时时间。如果删除缓存之后,数据同步到备库之前已经有请求过来时,「会从备库中读到脏数据」,如何解决呢?解决方案如下流程图:

缓存维护总结

综上所述,在分布式系统中,缓存和数据库同时存在时,如果有写操作的时候,「先操作数据库,再操作缓存」。如下:

  • 1.读取缓存中是否有相关数据
  • 2.如果缓存中有相关数据value,则返回
  • 3.如果缓存中没有相关数据,则从数据库读取相关数据放入缓存中key->value,再返回
  • 4.如果有更新数据,则先更新数据库,再删除缓存
  • 5.为了保证第四步删除缓存成功,使用binlog异步删除
  • 6.如果是主从数据库,binglog取自于从库
  • 7.如果是一主多从,每个从库都要采集binlog,然后消费端收到最后一台binlog数据才删除缓存

最后

作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料,如果**‘你’确定好自己未来的道路或者想学习提升自己技术栈、技术知识的小伙伴们可以点击这里来获取免费学习资料提升自己(全套面试文档、PDF、进阶架构视频)**


va-p7)提升自己(全套面试文档、PDF、进阶架构视频)**

[外链图片转存中…(img-uMgL2rKO-1626688897205)]
[外链图片转存中…(img-carA01Nh-1626688897205)]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【聊透SpringMVC】自学java和三大框架要多久

饿了么一面(Java) hashmap源码问题 HashMap底层结构 put操作讲一下 HashMap、HashMap如何保证线程安全、ConcurrentHashMap JVM有哪些回收算法,对应的收集器有哪些? jvm g1的内存模型讲一下,G1和CMS收集器的区别&#…

【设计思想解读开源框架】mysql官方文档中文版下载免费

01 源码分析 源码阅读,最核心有三点:技术基础强烈的求知欲耐心。 1.1 设计模式(45设计模式:介绍优缺点应用实例源代码解决问题) 1.2 Spring复习大纲:依赖注入IocBeans注解数据访问AOPMVC等 1.3 Spring全家…

命令新参

命令形参: 命令行参数是使用main()函数参数来处理的,其中,argc是指传入参数的个数,argv[]是一个指针数组,指向传递给程序的每个参数。 应当指出的是, argv[0]存储程序的名称,argv[1]是一个指向…

【金三银四】启动mysql服务器

微服务架构 ①微服务概念: ②Spring Cloud微服务架构: 海量数据处理 ①:经典的海量数据处理面试题 高可用架构 ①基于 Hystrix 实现高可用: ②限流: ③熔断: 高并发架构 ①消息队列: ②搜索…

函数fork vfork

一、函数fork fork函数原型&#xff1a; #include <unistd.h> pid_t fork(void); 二、程序清单 1. 测试代码&#xff1a; #include <unistd.h> #include <stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <string.h>…

【金三银四】微软java后端社招

分布式系统特性与衡量标准 透明性&#xff1a;使用分布式系统的用户并不关心系统是怎么实现的&#xff0c;也不关心读到的数据来自哪个节点&#xff0c;对用户而言&#xff0c;分布式系统的最高境界是用户根本感知不到这是一个分布式系统 可扩展性&#xff1a;分布式系统的根…

【面试必会】java虚拟机原理

如何才可以进大厂&#xff1f; 答案其实也很简单&#xff0c;能力学历。不知道大家有没有发现&#xff0c;大厂的一些部门对于学历要求已经放低了&#xff0c;阿里的一些部门同样也招大专学历的程序员&#xff0c;当然肯定也是因为他的能力足够出色。 对于准备秋招的你来说&a…

函数exec

exec函数族 1. 执行指定目录下的程序 #include <unistd.h> int execl(const char *path, const char *arg, ...);返回值&#xff1a;若出错&#xff0c;返回-1&#xff1b;若成功&#xff0c;不返回 分析&#xff1a; path: 要执行的程序的绝对路径变参arg: 要执行的…

【面试必备】java写spark好不好

并发编程三大特性 原子性 一个操作或者多次操作&#xff0c;要么所有的操作全部都得到执行并且不会受到任何因素的干扰而中断&#xff0c;要么所有的操作都执行&#xff0c;要么都不执行。 对于基本数据类型的访问&#xff0c;读写都是原子性的【long和double可能例外】。 …

【面试必备】java面试题视频讲解

二、我们先来看看这份笔记到底有什么 1、先把kubernetes跑起来&#xff08;先跑起来创建kubernetes集群部署应用访问应用Scale应用滚动更新&#xff09; 2、重要概念 3、部署kubernetes Cluster&#xff08;安装docker安装 kubelet.kubeadm和 kubectll用kubeadm 创建cluster&a…

【面试总结】java测试工程师培训

阿里P8级架构师核心理论落地篇 再造淘宝&#xff0c;贯穿全系&#xff0c;阿里团队代码落地&#xff0c;详细每个版本迭代&#xff0c;拒绝2-3个月PPT架构师再造淘宝之咚宝-技术支撑-完整搭建DevOps再造淘宝之咚宝-统一规则-代码规范落地解析再造淘宝之咚宝搭建基础服务再造淘…

进程组的应用

一、实验1 题目&#xff1a;利用进程扇完成一个小实验。该进程扇有 1 个父进程和 3 个子进程&#xff0c;我们希望达到图 1 中的效果&#xff0c;即将进程 0 (父进程)和进程 1 设置成一组&#xff0c;假设为组 1&#xff0c;将进程 2 和 进程 3 设置成另一个组&#xff0c;假设…

【原理+实战+视频+源码】docker映射端口教程

阿里巴巴Java岗面试题分享 1.HashMap 的内部结构&#xff1f;内部原理&#xff1f;和 HashTable 的区别&#xff0c;假如发⽣了 hash 碰撞&#xff0c;如何设计能让遍历效率⾼&#xff1f; 2.讲一讲讲讲 ConcurrentHashMap吧。 3.讲一下JVM虚拟机内存结构&#xff0c;以及它…

前台进程组、后台进程组

一、前台进程组、后台进程组 cat | cat & cat | cat | cat 输出结果&#xff1a; 二、主要函数应用 1. tcgetpgrp函数原型&#xff1a; #include <unistd.h> pid_t tcgetpgrp(int fd);返回值&#xff1a;若成功&#xff0c;返回前台进程组ID, 若出错&#xff0c;…

【原理+实战+视频+源码】docker权限参数

一面&#xff1a; 个人介绍加项目介绍20分钟 微服务架构是什么&#xff0c;它的优缺点&#xff1f; ACID CAP BASE理论 分布式一致性协议&#xff0c;二段、三段、TCC&#xff0c;优缺点 RPC过程 服务注册中心宕机了怎么办&#xff1f; 微服务还有其他什么组件 分布式架…

【孤儿进程】孤儿进程组、守护进程

一、孤儿进程组 1. 孤儿进程的定义&#xff1a; 定义1&#xff1a;该进程组的每个成员的父进程要么是该组的成员&#xff0c;要么在其它会话中。 定义2&#xff1a;一个进程不是孤儿进程组的条件是——该组有一个进程&#xff0c;其父进程在属于同一会话的另一个组中。 只要能…

【吐血整理】用java编写一个登陆界面

结构化数据、非结构化数据与半结构化数据 文章的开始&#xff0c;聊一下结构化数据、非结构化数据与半结构化数据&#xff0c;因为数据特点的不同&#xff0c;将在技术上直接影响存储引擎的选型。 首先是结构化数据&#xff0c;根据定义结构化数据指的是由二维表结构来逻辑表…

【大牛疯狂教学】cdhkafka打开的文件描述符临界阈值

基本知识 1.学会分析源码 程序员每天都和代码打交道。经过数年的基础教育和职业培训&#xff0c;大部分程序员都会「写」代码&#xff0c;或者至少会抄代码和改代码。但是&#xff0c;会读代码的并不在多数&#xff0c;会读代码又真正读懂一些大项目的源码的&#xff0c;少之…

线程清理函数

一、线程清理函数 #include <pthread.h> void ptread_clean_push(void (*rtn) (void *), void *arg); 注册清理函数&#xff0c;押栈 void ptread_clean_pop(int excute); 清理函数&#xff0c;出栈 分析&#xff1a;这两个函数是成对出现的…

【大牛疯狂教学】mysqlinnodb和myisam

02 JVM 线程JVM内存区域JVM运行时内存垃圾回收与算法JAVA四种引用类型GC分代收集算法 VS 分区收集算法GC垃圾收集器JAVA IO/NIOJVM类加载器 03 JAVA集合 接口继承关系和实现LISTSETMAP 04 JAVA多线程并发 JAVA并发知识库JAVA线程实现/创建方式4种线程池线程生命周期&#xf…