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

营销型平台网站建设今日国家新闻

营销型平台网站建设,今日国家新闻,wordpress弹出框,wordpress数据库用户角色在系统中缓存最常用的策略是:服务端需要同时维护DB和cache,并且是以DB的结果为准–Cache-Aside Pattern(缓存分离模式、旁路缓存) 读数据 单纯的读数据是不会产生数据不一致,只有并发下读和写才会存在数据不一致。 写…

在系统中缓存最常用的策略是:服务端需要同时维护DB和cache,并且是以DB的结果为准–Cache-Aside Pattern(缓存分离模式、旁路缓存)

读数据

在这里插入图片描述

单纯的读数据是不会产生数据不一致,只有并发下读和写才会存在数据不一致。

写数据

  1. 更新缓存再更新数据库
  2. 删除缓存再更新数据库
  3. 更新数据库再更新缓存
  4. 更新数据库再删除缓存

以上操作步骤总结下来就是两点:

  • 更新缓存还是删除缓存?
    • 推荐使用删除,因为缓存的更新成本更高,因为写入缓存的值一般要经过一系列复杂的计算再写入缓存;删除缓存操作简单,副作用只是增加了一次cache miss
  • 先操作缓存还是先操作数据库?

数据不一致

先操作缓存

image

经过上述过程之后,出现了数据不一致;redis中是老的数据,而DB中是新的数据(写延迟);所有后续其他的线程都是从缓冲中拿到的老数据,直至该老数据缓存过期。

如何解决这种情况下的数据不一致性?
image

通过延迟双删的策略可以解决,且保证了最终一致性。虽然线程2依然拿到的是老数据,但是后面的线程拿到的都是新数据。

最终一致性:最终能够保证redis和DB的一致性。
强一致性:redis操作和DB操作设置成原子操作,虽然保证了一致性但是降低了吞吐量,违背了使用redis的初衷。

先操作数据库

image

通过先操作数据库,然后操作缓存,虽然线程2在删除之前拿到的是老数据(脏数据),但是可以保证最终一致性,推荐使用该方式

删除重试

上述两种方式不管是延迟双删还是先操作数据库,保证最终一致性的前提是删除缓存成功,如果在极端条件下删除缓存失败怎么办?
在这里插入图片描述

如上图所示,通过向MQ发送异步消息,通知客户端进行重试删除来解决。引入canal组件,可将该删除重试功能从业务代码中解耦,canal客户端可以使用springboot应用来实现。

http://www.dtcms.com/wzjs/520651.html

相关文章:

  • 如何做h5 网站打开浏览器直接进入网站
  • 做全世界的生意的网站厦门百度快速优化排名
  • wordpress url中文键词优化排名
  • 做原油的网站查看今日头条
  • 邯郸房地产市场信息网seo网站自动发布外链工具
  • 网站建设需求参考文档秦皇岛seo排名
  • 用vue.js做网站建立网站一般要多少钱
  • 上海网站优化公司近期时政热点新闻20条
  • 六盘水网站开发百度竞价排名利弊
  • 公司注册资金可以变更减少吗网站排名seo软件
  • 在线做字网站刷关键词的平台
  • 成品网站哪个好sem运营
  • 做网站备案必须是个人还是公司网站引流推广怎么做
  • 网站建设的优势网站404页面怎么做
  • 企业网站制作 南京美国疫情最新数据消息
  • 怎么做自己的一个网站网络营销推广经验总结
  • 温州做网站公司哪家好销售平台软件有哪些
  • 做两个阿里网站抖音视频seo霸屏
  • 温州网站制作网站免费行情网站app大全
  • 网站搭建和网站开发武汉网络推广有限公司
  • 九江做网站的公司如何建立电商平台
  • 深圳网站制作必推祥奔科技海口网站关键词优化
  • 鄂州建设网站机器人编程培训机构排名
  • 更合高明网站建设2022磁力链接搜索引擎推荐
  • 中国水利建设网站网页友情链接
  • 网站的建设与开发直播营销的优势有哪些
  • 做网站好的框架搭建网站的五大步骤
  • 有没有专门做字体排版设的网站网站推广优化流程
  • 代做计算机毕业设计网站大型集团网站建设公司
  • 日本广告巨头遭突击搜查网站seo谷歌