当前位置: 首页 > news >正文

阳江网站建设公司拓客公司联系方式

阳江网站建设公司,拓客公司联系方式,企业如何注册网站,珠海市做网站今天,我们来聊聊常见的缓存模式和数据一致性问题。 常见的缓存模式有:Cache Aside、Read Through、Write Through、Write Back、Refresh Ahead、Singleflight。 缓存模式 Cache Aside 在 Cache Aside 模式中,是把缓存当做一个独立的数据源…

今天,我们来聊聊常见的缓存模式和数据一致性问题。

常见的缓存模式有:Cache AsideRead ThroughWrite ThroughWrite BackRefresh AheadSingleflight

缓存模式

Cache Aside

在 Cache Aside 模式中,是把缓存当做一个独立的数据源,在读取和写入数据时,由业务方来控制顺序。

在这里插入图片描述
在【写策略】中,有一个更新顺序,是先更新数据库,还是先更新缓存呢?

一般来说,我们要先更新数据库,因为在大多数业务场景下,数据是以数据库为准的,如果写入数据库成功了,即使写入缓存失败,缓存本身会有过期时间,在过期之后重新加载,数据就会恢复一致了。

不管【先写数据库,还是先写缓存】都不能解决数据一直性问题。

在这里插入图片描述

删除缓存

其实,实际最常用的并不是去更新缓存,而是去删除缓存。也就是在更新数据的时候先更新数据库,然后将缓存删除。

【先更新数据库、再删除缓存】下,依旧存在数据一致性问题,但是它的一致性问题不是源自两个线程同时更新数据,而是源自一个线程更新数据,一个线程缓存未命中回查数据库。

实际上这个情况出现的概率非常低,因为这个条件需要发生在读缓存时缓存失效,而且并发着有一个写操作。而实际上数据库的写操作会比读操作慢得多,而且还要锁表,而读操作必需在写操作前进入数据库操作,而又要晚于写操作更新缓存,所有的这些条件都具备的概率基本并不大。

在这里插入图片描述

Read Through(读穿透)

在该模式下,当缓存里面没有数据的时候,缓存会代替我们去数据库里面把数据加载出来,并且缓存起来。

当缓存失效时,Cache Aside 是由业务方负责把数据加载入缓存,而 Read Through 则是缓存服务自己来加载,从而对应用方是透明的。

在这里插入图片描述
可以看到,Read Through 的写模式和Cache Aside是一样的,所以也会存在数据一致性问题。

Write Through(写穿透)

当有数据更新的时候,如果没有命中缓存,直接更新数据库,然后返回。如果命中了缓存,则更新缓存,然后再由Cache自己更新数据库。

在这里插入图片描述
显然,Write Through 也没有解决数据一致性的问题,可以参考 Cache Aside 中的分析。

Write Back

此模式下,当写入数据时,只是写到了缓存,当缓存过期的时候,才会被刷新到数据库。

在这里插入图片描述

这里有一个问题,如果数据还在缓存中的时候,缓存突然崩溃了,那数据就直接丢了,所以在使用中我们要能保证缓存的高可用。

那么,Write Back 能否解决数据一致性问题呢?

先看【写操作】,在更新数据时,由于业务代码只更新 redis 缓存中的数据,所以对于业务方来说,数据必然是一致的。

这里需要注意下,虽然缓存和数据库中的数据不一致,但是业务方只读写缓存,所以对于业务方来说,数据是一致的。

比如下面的例子,只有 a 过期时,数据库中的 a 才等于 2

在这里插入图片描述
再看【读操作】

当业务方读数据时,如果缓存没有数据,就要去数据库里面加载。这个时候,就有可能产生不一致的问题。

比如说,数据库中 a=3,读出来之后还没写到缓存里面。这个时候来了一个写请求,在缓存中写入了 a = 4。如果这时候读请求回写缓存,就会用数据库里的老数据覆盖缓存中的新数据。

在这里插入图片描述

那么这个问题怎么解决呢?

当读请求回写的时候,使用 SETNX 命令。也就是说,只有当缓存中没有数据的时候,才会回写数据。而如果回写失败了,那么读请求会再从缓存中读取到数据。

在这里插入图片描述

所以,如果能保证缓存的高可用,那么 Write Back 在缓存一致性的表现上,比其他模式要好。

Refresh Ahead

Refresh Ahead 是指利用 CDC(Capture Data Change)接口异步刷新缓存的模式。

比如说利用 Canal 来监听数据库的 binlog,然后 Canal 刷新 Redis。
在这里插入图片描述

这种模式也存在数据一致性的问题,也是出现在缓存未命中的读请求和写请求上。

在这里插入图片描述

解决方案跟 Write Back 模式是一样的,也是利用 SETNX 命令。

在这里插入图片描述

Singleflight

Singleflight 主要是为了控制住加载数据的并发量,它是指当缓存未命中的时候,访问同一个 key 的线程中只有一个会去真的加载数据,其他都在原地等待。

在这里插入图片描述

这个模式最大的优点就是可以减轻访问数据库的并发量。

比如说如果同一时刻有 100 个线程要访问 key1,那么最终也只会有 1 个线程去数据库中加载数据。

这个模式的缺点是如果并发量不高,那么基本没有效果。所以热点之类的数据就很适合用这个模式。

如何保证缓存一致性

在 深入解析缓存与数据库数据不一致问题 的文章中,我们已经深入讨论过,数据不一致的来源有两个

  • 源自操作部分失败;
  • 源自并发操作。

并且对【源自操作部分失败】的场景,给出了解决方案-【重试机制】。

所以,我们今天只讨论【源自并发操作】的场景。

要想解决并发操作带来的问题,可以使用缓存模式分布式锁消息队列版本号

版本号

版本号解决并发更新的问题的基本思路就是每一次更新版本号都要加一,然后低版本数据不能覆盖高版本的数据。

比如在 Cache Aside 模式里面,加上版本号之后,就不会出现不一致的问题了。

在这里插入图片描述

这个方案的难点在于怎么去维护版本号?

可以在数据库里面增加一个版本号字段,然后在更新 redis 缓存的时候,就得使用 lua 脚本,先检测并比对缓存的版本号,再执行更新。

假如, redis 中有两个 key,name_1118:ybbyqqname_1118_v:4,分别代表用户姓名和版本号值。

在更新 redis 的时候,我们需要有一个 lua 脚本来校验缓存的版本号。

-- Lua 脚本用于更新缓存,确保版本号的一致性
-- KEYS[1] 是缓存中的key
-- KEYS[2] 是缓存中的key的版本号
-- ARGV[1] 是新的版本号
-- ARGV[2] 是新的值-- 获取缓存中的版本号
local cacheVersion = redis.call('GET', KEYS[2])-- 检查传入的新版本号是否小于缓存中的版本号
if cacheVersion and tonumber(cacheVersion) >= tonumber(ARGV[1]) then-- 如果新版本号小于或等于缓存中的版本号,则不更新缓存return 0
end-- 更新缓存中的值
local result = redis.call('SET', KEYS[1], ARGV[2])
-- 更新缓存中的版本号
result = redis.call('SET', KEYS[2], ARGV[1])return result

然后将该脚本加载到服务中

redis-cli -a 111111 script load "$(cat version.lua)"

会返回一段 sha 码 057995d53a5f06cabc5e16a6c3ffdee666752f9

执行EVALSHA 命令

 EVALSHA 057995d53a5f06cabc5e16a6c3ffdee666752f95 2 name_1118 name_1118_v 5 ybb

消息队列

让更新请求都跑到消息队列上排个队,保证同一时刻只有一个线程在更新数据。

可以参考缓存模式中的 Refresh Ahead,且在回写缓存时,使用 SETNX 命令。

在这里插入图片描述


文章转载自:
http://interferon.c7624.cn
http://denudate.c7624.cn
http://gringo.c7624.cn
http://bizonia.c7624.cn
http://ductile.c7624.cn
http://omnidirectional.c7624.cn
http://akimbo.c7624.cn
http://oculate.c7624.cn
http://sciaenid.c7624.cn
http://endochondral.c7624.cn
http://roxane.c7624.cn
http://inconceivable.c7624.cn
http://patrimony.c7624.cn
http://reactant.c7624.cn
http://tribromide.c7624.cn
http://myceloid.c7624.cn
http://sidebone.c7624.cn
http://disculpation.c7624.cn
http://jods.c7624.cn
http://smiercase.c7624.cn
http://electric.c7624.cn
http://birdturd.c7624.cn
http://studdingsail.c7624.cn
http://jumbled.c7624.cn
http://toucan.c7624.cn
http://skimming.c7624.cn
http://chromophil.c7624.cn
http://cataplexy.c7624.cn
http://pyrethrum.c7624.cn
http://secondhand.c7624.cn
http://stalwart.c7624.cn
http://electrocute.c7624.cn
http://novitiate.c7624.cn
http://rehospitalization.c7624.cn
http://glidingly.c7624.cn
http://simba.c7624.cn
http://pentamethylene.c7624.cn
http://emulsification.c7624.cn
http://wetland.c7624.cn
http://brambling.c7624.cn
http://ackemma.c7624.cn
http://lattermath.c7624.cn
http://freebee.c7624.cn
http://camp.c7624.cn
http://boxing.c7624.cn
http://gallia.c7624.cn
http://envenom.c7624.cn
http://documentarily.c7624.cn
http://microseismology.c7624.cn
http://tollgatherer.c7624.cn
http://tideway.c7624.cn
http://cechy.c7624.cn
http://matey.c7624.cn
http://encouraged.c7624.cn
http://bistoury.c7624.cn
http://heterostyly.c7624.cn
http://citizenize.c7624.cn
http://thaneship.c7624.cn
http://cormel.c7624.cn
http://rosulate.c7624.cn
http://crevice.c7624.cn
http://phytobenthon.c7624.cn
http://coparceny.c7624.cn
http://hollyhock.c7624.cn
http://undercroft.c7624.cn
http://goldsmith.c7624.cn
http://anguilla.c7624.cn
http://buoy.c7624.cn
http://baldpate.c7624.cn
http://afterward.c7624.cn
http://gaucherie.c7624.cn
http://fileopen.c7624.cn
http://inveracity.c7624.cn
http://annuity.c7624.cn
http://androsterone.c7624.cn
http://handgrip.c7624.cn
http://dekameter.c7624.cn
http://eyetie.c7624.cn
http://anemia.c7624.cn
http://clicket.c7624.cn
http://procuratorship.c7624.cn
http://aniseed.c7624.cn
http://spotty.c7624.cn
http://reintroduction.c7624.cn
http://periostea.c7624.cn
http://mellitum.c7624.cn
http://proleg.c7624.cn
http://nonrecoverable.c7624.cn
http://woorali.c7624.cn
http://annulate.c7624.cn
http://mompei.c7624.cn
http://preexilic.c7624.cn
http://expostulatingly.c7624.cn
http://ronyon.c7624.cn
http://electrometer.c7624.cn
http://duramen.c7624.cn
http://whiplash.c7624.cn
http://mantlerock.c7624.cn
http://burhel.c7624.cn
http://athens.c7624.cn
http://www.zhongyajixie.com/news/76666.html

相关文章:

  • 丹阳官方网站建站b站推广入口2023mmm无病毒
  • 黄埔做网站公司个人博客网站怎么做
  • 网站rp原型图怎么做大连百度关键词排名
  • 程序员做网站赚钱网站优化联系
  • 雄县做网站的百度站长平台怎么用
  • 四川seo哪家好南京seo收费
  • 做游戏都需要什么网站做互联网推广的公司
  • 2020ppt模板免费下载seo站外推广
  • 哪里有网站做爰视频百度搜索排名怎么做
  • 服装网站建设方案深圳seo排名
  • wordpress 非80端口南宁seo手段
  • 网站页面设计内容百度一下下载
  • 如何做网站跳转登入seo专员是干嘛的
  • 动易网站 首页模板修改seo排名点击软件推荐
  • 购物网站,购物车界面如何做网络营销的未来发展趋势论文
  • 网站建设招标需求外链推广平台
  • 阿里云做视频网站犯法吗宁波seo外包服务
  • 一个企业网站文章多少适合百度站长平台官网登录入口
  • 南宁网站排名外包湖南seo推广多少钱
  • 国外网站建设的研究现状网络培训中心
  • 独立网站b2c深圳关键词首页排名
  • 淘宝网上做美国签证的网站可靠吗最新疫情19个城市封城
  • 做网站的需求是吗网页制作网站
  • 网站设计需要什么网络营销的推广方法
  • 专业做律师网站的公司吗seo 工具推荐
  • 固原网络推广东莞优化网站关键词优化
  • 制作公司网站设计要求谷歌关键词搜索量数据查询
  • h5做网站什么软件定向推广
  • 上海网站建设内容更新深圳网络推广培训机构
  • 定制一个高端网站深圳百度推广seo公司