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

做网站用身份证欧洲站fba

做网站用身份证,欧洲站fba,餐饮网站建设,重庆市建设工程信息网怎么查不到市外施工单位一,使用方案 在使用redis作为缓存的场景下,我们一般使用流程如下 二,更新数据场景 我们此时修改个某条数据,如何保证mysql数据库和redis缓存中的数据一致呢? 按照常规思路有四种办法,1.先更新mysql数据&a…
一,使用方案

在使用redis作为缓存的场景下,我们一般使用流程如下

在这里插入图片描述

二,更新数据场景

我们此时修改个某条数据,如何保证mysql数据库和redis缓存中的数据一致呢?
按照常规思路有四种办法,1.先更新mysql数据,再更新缓存数据 2.先更新缓存数据,再更新mysql数据
3.先删除缓存,再更新mysql数据 4.先更新mysql数据,再删除缓存 。
这四种方法各有各的弊端,并不能完全保证数据一致性,采用“先写 MySQL,再删除 Redis”的策略,这种情况虽然也会存在两者不一致,但是需要满足的条件有点苛刻,所以是满足实时性条件下,能尽量满足一致性的最优解。对于不是强一致性要求的业务,可以容忍。(什么情况下不能容忍呢,比如秒杀业务、库存服务等。)
为什么采用删除缓存而不是更新缓存,是因为高并发下产生脏数据的要求要比更新缓存的要求更多,也就是删除缓存产生脏数据的概率更小一些。
那么问题又来了,在高并发的情况下
采用先删除缓存,再更新数据库

  • 请求A来了,删除缓存
  • 请求A更新数据库,发生卡顿,同时来了请求B
  • 请求B发现没有缓存,就从数据库查询了数据,并生成了缓存
  • 此时请求A卡顿结束,更新了数据库
    这个情况下,缓存中的就是脏数据。我们采用延时双删来解决
    在这里插入图片描述
    那么问题又来了,第二次删除缓存失败了怎么办?看下面
  • 先更新数据库,再删除缓存
    如果删除缓存失败,怎么保证数据一致性?
    1.使用重试机制,可以直接在接口中重试,但是比较耗费性能
    2.使用异步队列重试
    3.使用rabbitmq消息中间件来处理
    当用户操作写完数据库,但删除缓存失败了,产生一条mq消息,发送给mq服务器。
    mq消费者读取mq消息,重试5次删除缓存。如果其中有任意一次成功了,则返回成功。如果重试了5次,还是失败,则写入死信队列中。
    当然在该方案中,删除缓存可以完全走异步。即用户的写操作,在写完数据库之后,不用立刻删除一次缓存。而直接发送mq消息,到mq服务器,然后有mq消费者全权负责删除缓存的任务。
    因为mq的实时性还是比较高的,因此改良后的方案也是一种不错的选择。

总结:以上方法只能保证最终一致性,不能保证强一致性

http://www.dinnco.com/news/10838.html

相关文章:

  • 杭州pc网站开发公司有哪些怎么开发自己的网站
  • 不会编程如何做自己的网站爱链接
  • 九江网站制作网络销售
  • 在线建设网站制作南京seo排名公司
  • 网站报价预算书外贸网络推广怎么做
  • 运营公众号还是做网站关键词排名批量查询软件
  • wordpress 企业网站制作西安竞价托管代运营
  • 网站是什么时候出现的聊城seo培训
  • 专业网站制作流程如何自己开发软件app
  • 如何帮助网站吸引流量网站推广网络营销
  • 中山网站方案汕头最好的seo外包
  • 呼市网站建设seo免费优化网址软件
  • 个人备案的域名拿来做经营网站百度推广客服工作怎么样
  • 淘宝客购物网站源码seo方法培训
  • 深网网站google搜索关键词热度
  • 阜宁做网站哪家公司最好百度快速收录教程
  • 做外语网站的公司百度推广客户端怎样注册
  • 没有网站做cpa怎么赚钱独立网站和平台网站
  • 郑州网站建设批发长沙seo研究中心
  • 网站logo名词解释mac923水蜜桃923色号
  • 网页设计公司有专门做图的部门seo软件排行榜前十名
  • 专门做验收报告的网站微信营销方式
  • 做团购网站有什么难处北京搜索引擎推广服务
  • 代办网站备案爱站seo工具
  • php动态网站开发的优点枸橼酸西地那非片功效效及作用
  • 万网网站公安备案系统谷歌浏览器2021最新版
  • 汕头市濠江区政府门户网站上海高端网站定制
  • 灵武市建设银行网站企业网络营销推广方案
  • 软件ui设计教程多合一seo插件破解版
  • 物流网站怎么做代理网站关键字优化价格