数据库缓存双写一致性的一些个人想法

数据库缓存双写一致性的一些个人想法

有这么个问题,还是经典面试题:

说我们有个数据库,他的读请求特别多,以至于要在数据库上加一层缓存来抗压,这个都能理解吧。
这里的缓存,可能是和数据库一样的数据,也可能是数据库的数据经过一系列复杂运算,得出的结果。
但是涉及到更新数据库内容的时候,如何能保证缓存也能同时更新呢

先说说网友的说法:

1、先删除缓存,再更新数据库,再更新缓存(容易造成脏读)

2、先删除缓存,再更新数据库,然后等若干毫秒,再删除缓存,再更新缓存(降低吞吐量)

3、先删除缓存,再更新数据库,同时把这个更新的请求放在队列中,后面有读这个即将更新的数据的请求,如果发现缓存没数据,会再队列中看一眼,发现这条数据正在更新的话,就轮询着查缓存,直到查到数据,否则一段时间后,要么超时返回,要么返回旧数据。

4、还有一些反例的说法,比如先更新缓存再更新数据库之类的,我这里就不多解释这样做的问题了。

关于这个问题,现在我说下我的理解,可能与网上其他说法略有差异

1、首先确认一点,什么时候应该用缓存,那就是读多写少的情况。一般应用都是这样,如果你的场景不是读多写少的,我还是不建议使用缓存的,因为写操作一多,就涉及到事务相关了,数据库已经把事务做的那么完善了,你非要在上面加个缓存自己再实现一遍,出了问题不是自找么。

2、还有,如果你的系统,对准确性要求特别高,比如涉及到钱的计算,比如转账,那也不建议用缓存,直接加机器吧,把数据库分片,分的片越多,性能越好,而且这种情况一般都有唯一id,比如账号,而对于同一个账号,基本不会出现什么并发,所以老老实实用数据库就行了。

3、除了以上这两种情况,那数据库缓存双写一致性,那还说个啥。想要数据库缓存一致,就必须牺牲吞吐率,而加缓存的原因,就是读请求太多,吞吐率跟不上了,那为了解决一致性,反而把吞吐量又降低了,这不有点自相矛盾么。

总结:

有时候,我们发现问题,就一定要解决,当然这是一个很好的习惯。

但如果你作为一个项目的负责人或者技术负责人,在技术层面加了时间观念,就是不仅要把技术搞好,还要把项目搞好,要尽快搞好,那就不能单纯的看技术了,还要多方面考虑。

因为有些问题,其实是可以绕过的,就比如这个数据库缓存一致性,如果你的项目实在是解决不了这个一致性,不妨不要解决了,退一步,试试不用缓存,还有没有其他方案,比如增加数据库抗压能力等等。

当然,以上都是我的个人一些想法,不一定都对,如果你有任何想法,欢迎交流。

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

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

相关文章

2020年规划

1.去其他城市,市级城市超过3个。 2.继续想着通过其他方式赚钱。 3.选一个技术体系,搞精通,比如数据库,比如高并发分布式等 4.搞个自己的网站,国庆前平均每天100访问量。 5.12点前睡觉 2020年1月5日,2020年…

实用的java代码生成器,开箱即用(基于mybatisplus的AutoGenerator)

spring-boot工程下&#xff0c;自动生成代码&#xff0c;controller层&#xff0c;service层&#xff0c;mapper层。 根据数据库配置好的表&#xff0c;逆向生成实体类和各层结构 1、引入maven <dependency><groupId>com.baomidou</groupId><artifactId&…

mac/windows 端口占用解决记录

idea启动报错&#xff1a;端口占用 The port may already be in use or the connector may be misconfigured mac端口占用解决 zhangshuaideMacBook-Pro:~ zhangshuai$ lsof -i:8095 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME Google 375 zhangshuai 32u IPv6 0x…

[配置中心] --- consul

mac下载安装consul 1、下载&#xff1a;consul下载地址 2、解压到目录/usr/local/bin下 3、执行consul文件 4、验证&#xff1a;控制台输入consul验证 5、启动consul&#xff1a;consul agent -dev windows安装consul 1、下载&#xff0c;解压到D:\soft&#xff0c;将这个路…

[java基础] --- java开发,service层是不是一定要写接口

估计很多java开发的同学都遇到过&#xff0c;service层要写一个接口&#xff0c;然后再写接口的实现类&#xff0c;但这个接口从项目开始到项目倒闭&#xff0c;都不会有第二个实现&#xff0c;那为什么不直接写个service类呢&#xff1f;如果你还没想过这个问题&#xff0c;那…

浅谈权限(功能权限数据权限)

一般企业上的权限部分&#xff0c;都是区分为功能权限和数据权限。 一、功能权限 功能权限&#xff0c;就是用户登录后&#xff0c;能看到哪些菜单&#xff0c;能看到哪些按钮&#xff0c;能执行哪些操作的权限。 一般&#xff0c;功能权限&#xff0c;已经都有很成熟的业内方…

一个技术负责人应该知道的规范细节

前言&#xff1a; 作为一个技术负责人&#xff0c;不能只定义一个项目的技术选型&#xff0c;而不注意开发细节。 开发前&#xff0c;如果不预先定义好规范&#xff0c;那么项目中就会乱成一锅粥。每个人自成一派&#xff0c;单看每个人的模块&#xff0c;貌似都没啥大问题&am…

skywalking(1) 基于opentracing规范的APM系统

skywalking是&#xff1a; 基于opentracing规范的APM系统 skywalking解决了什么问题&#xff1f; skywalking解决微服务架构下&#xff0c;多服务直接复杂的调用关系 了解dapper&#xff0c;分布式链路追踪系统 dapper又是谷歌论文&#xff0c;各公司又相继模仿。&#xff…

skywalking(2)

安装 1、安装jdk 2、安装es 3、安装skywalking&#xff08;backend和ui&#xff09; 应用启动时添加探针&#xff08;agent&#xff09; 使用 java -javaagent:/aa/bb/boot.jar -Dserver.port8081 -jar boot.jar 启动项目jar包 查看调用链&#xff0c;追踪等 仪表盘&#…

skywalking(3)

javaagent原理 skywalking实现代码无侵入&#xff0c;就是用了javaagent javaagent是java命令的一个参数&#xff0c;可以用于指定一个jar包 这个jar包中的MANIFEST.MF中&#xff0c;必须指定Premain-Class项 Premain-Class指定的那个类&#xff0c;必须实现premain()方法 当…

skywalking(4)

Byte Buddy库 统计方法调用时长 1、增强字节码 2、拦截器拦截 类似于spring的aop&#xff0c;只不过skywalking不能用aop&#xff0c;所以用Byte Buddy技术代替 Open Trace 整个trace调用&#xff0c;是由多个span组成的有向无环图&#xff08;就是调用关系图&#xff09;。…

kubernetes(k8s)

应用部署演进过程 我们从上图可以看到&#xff0c;应用越来越看重应用本身了&#xff0c;慢慢的不受物理机的差异&#xff0c;不受操作系统的差异&#xff0c;开发者可以花更多精力去到应用本身。 k8s概念 简单理解&#xff0c;k8s就是传统的云平台上的linux。 kubernetes是…

jenkins+k8s实现持续集成

持续集成&#xff08;CI&#xff09; 集成是指开发人员将代码提交到git或svn 持续集成是指让开发人员持续提交代码&#xff0c;写一点就提交一点&#xff0c;这样就会更早的发现代码差异 每次集成&#xff0c;都可以通过自动化的构建来验证 自动化构建包括&#xff1a;编译&am…

为什么要用Elasticsearch

概念 Elasticsearch 简称ES&#xff0c;是一个分布式全文检索引擎。 比如github的代码检索就是用了ES&#xff0c;百度也有用ES。 由于Lucene的api相对比较复杂&#xff0c;所以ES其实是对Lucene的封装简化&#xff0c;并且提供了一套比较简单的api文档。 es官网 使用场景 主…

[设计模式] ------ 建造者模式(对比模板模式)

建造者模式 建造者模式&#xff0c;是为了构建一类具有相同执行顺序的但实现不一样&#xff0c;最后产生不一样的东西的效果。 举个例子&#xff0c;比如写作文。 每次写作文&#xff0c;我们大致有写标题&#xff0c;写开头&#xff0c;写内容&#xff0c;写结尾这些步骤。…

[设计模式] ------ 观察者模式和他的升级版发布订阅模式

概念 观察者模式&#xff0c;原理很简单&#xff0c;把A类的子类分别注入到B类中&#xff0c;通过用B类调用方法&#xff0c;循环调用A类的方法&#xff0c;就是所谓观察者模式 伪代码如下&#xff0c;最快的速度理解观察者模式&#xff1a; 接口 A{// 观察者接口notify(); …

[设计模式] ------ 工厂方法模式

工厂方法模式 手机厂造手机&#xff0c;肥皂厂造肥皂&#xff0c;药品厂造药品。 假设有一大类对象A1,A2,A3,A4…他们都有一个共同的父类A A1可以想成是手机&#xff0c;A2可以想成肥皂… &#xff08;下面例子的A1Factory就是手机厂&#xff0c;A2Factory就是肥皂厂&#x…

[设计模式] ------ 抽象工厂模式

抽象工厂模式 抽象工厂模式&#xff0c;就是对工厂方法模式加以改进而已&#xff0c;其实就是用简单工厂模式的套路创建各个工厂&#xff0c;后面和工厂模式就一模一样了。 其实就是相当于将创建哪个工厂的权利再次放给调用端。 调用端在调用的时候&#xff0c;指定用哪个工厂…

[设计模式] ------ 对比总结:简单工厂模式、工厂方法模式、抽象工厂模式

三个概念&#xff1a; 简单工厂模式&#xff1a;就是一个简单的工厂类&#xff0c;根据不同的入参类型&#xff0c;返回不同的父类引用的子类对象。 工厂方法模式&#xff1a;就是将生成哪个子类对象的过程&#xff0c;延迟到工厂子类实现&#xff0c;工厂父类只定义接口。 抽…

[设计模式] ------ 原型模式(浅拷贝和深拷贝)

原型模式 原型模式就是使用复制对象&#xff0c;创建出新的对象&#xff0c;并且不需要知道创建的细节&#xff08;比如类的属性的赋值等等&#xff09;。 基本使用&#xff08;浅拷贝&#xff09; 常见的就是使用Object的clone方法。需要让类实现Cloneable并重写clone方法&…