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

网站建设方案下载全网营销推广方案

网站建设方案下载,全网营销推广方案,互联网公司排名世界,浙江网站建设哪家好Redis的作用 一般情况下Redis是用来实现应用和数据库之间的一个读操作的缓存层,主要目的是减少数据库的io,还可以提升数据库io性能 方法一: 先更新MySQL数据库,再删除缓存,再从数据库查询到的最新的数据同步到redis…
Redis的作用

一般情况下Redis是用来实现应用和数据库之间的一个读操作的缓存层,主要目的是减少数据库的io,还可以提升数据库io性能

方法一:

先更新MySQL数据库,再删除缓存,再从数据库查询到的最新的数据同步到redis。采用最终一致性性策略。

缺点:相较于mq的方式,这种方式由于要查数据库并将最新数据写到redis,可能会造成接口响应速度变慢。

方法二:

更新mysql数据库,再采用mq异步的方式,将数据同步到redis中。

缺点:数据同步延时概率比较大,数据库的更改信息投递到mq中,消费者可能没来得及消费消息同步数据到redis。

优点:异步解耦

方法三:

基于订阅mysql binlog,采用mq异步的形式将数据同步到redis(canal框架)。

将mysql以主从的方式部署,主库负责写,从库负责读,当主库的binlog日志文件发生改变时,将信息同步到从库,从库执行对应的sql,保证主从一致性。

canalServer端,伪装成mysql的从节点,订阅mysql主节点的binlog文件,当主节点的binlog发生变化时,会将binlog日志文件发送给canalServer端,自己创建的处理程序连接到canalServer端,将数据同步到redis。

优点:手动直接更改数据库也会自动同步到redis。

方法四:

延时双删策略(不推荐)

  • 先删缓存,在更新mysql并同步到redis,在高并发的情况下,第一个线程还没来得及更新mysql时,其他线程读取到的缓存可能为null值,将mysql旧的数据同步到redis中了。

解决办法:延时删除,在t1线程更新数据库之后,sleep一段时间再去删除缓存。

缺点:t1线程延时多少秒再去删除缓存中的key?难以控制,得根据业务逻辑的执行时间和写缓存的时间来进行估算。

补充:什么是双写一致性协议?

先更新数据库,在更新缓存。

updateDB();
updateredis();

多个线程同步修改mysql和redis时,由于mysql行锁机制,多个线程同时修改同一行数据,只能有一个线程修改成功,两个线程更新完数据库后同时更新redis,由于不能确保两个线程更新缓存的先后顺序,可能会造成数据库和缓存的不一致性。

解决办法:使用事务保证更新数据库和更新缓存整个两个操作的原子性。

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

相关文章:

  • 湖南建设网站哈尔滨最新
  • 秦皇岛手机网站制作价格互联网销售是什么意思
  • 石家庄兼职建站产品推广平台排行榜
  • 电脑什么软件可以做动漫视频网站广告联盟平台
  • 哪里可以检测艾滋病荆州seo推广
  • 赤峰最好的网站建设公司百度seo怎么操作
  • 如何分析竞争对手的网站疫情最新情况
  • 沈阳建设工程管理中心自己怎么优化关键词
  • 中山做外贸网站网络广告一般是怎么收费
  • 多语言网站建设费用外贸营销网站建站
  • 国际著名平面设计作品网站关键词免费优化
  • 怎样做网站卖手机号百度搜索网页
  • 自学java 做网站 多久站长统计ios
  • 雅安网站建设数字营销公司排行榜
  • 网站开发能赚钱吗地推扫码平台
  • 石家庄网站优化推广搜狗搜索网页版
  • 怎么做点击图片跳转网站优化防疫政策
  • 武汉网站建设_网页设计_网站制作_网站建设公司_做企业网站公司网上竞价
  • 长沙seo优化价格百度竞价优化
  • pc网站制作APP上海seo顾问
  • 怎么做电影网站服务器站长工具视频
  • 西安建设银行网站google play官网下载
  • wordpress网站代码优化百度的企业网站
  • 做机电证的网站常州seo第一人
  • 四川移动网站建设站长工具seo综合查询下载
  • 怎样做公司网站营销的主要目的有哪些
  • 上海网站制作官网班级优化大师下载安装app
  • 济南制作网站公司cps广告联盟平台
  • 网站管理设置企业如何注册自己的网站
  • 免费建国外网站百家号权重查询