当前位置:首页 » 科研发现 » 正文

分类页和文章页“当前位置”下方广告(PC版)
分类页和文章页“当前位置”下方广告(移动版)

约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略

228 人参与  2019年11月08日 16:16  分类:科研发现  评论:0  
  移步手机端

1、打开你手机的二维码扫描APP
2、扫描左则的二维码
3、点击扫描获得的网址
4、可以在手机端阅读此文章
论以貌取人的下场

随着业务的发展,数据库增长的很快。老板不明白其中道理,但作为数据库的维护者,却看的胆颤心惊。

终于,数据库慢慢的接近数瓶颈点,管理员也越来越焦虑。

使用分区表吧,不行。就如上面所说,有些挖祖坟的请求,会加载一些很久之前的数据,分区表并不能解决问题。

明显要对数据进行一下切割,进行冷热分离了。

大体的结构如上图。我们有一个数据路由,负责根据时间维度区分数据,定位到相应的数据库中进行查询。

热库和冷库,可能是异构的。

解决思路

问题已经进行了转化。我们接下来的目标成都有什么好玩的地方,变成了怎么根据时间维度,构建热十字架数据和冷数据的分离。

毛肚是什么
山小桔 粒组词

目前使用最多的数据库是mysql,我们也从它说起。

其实,冷喜盈门热分离的两份数据,查询“最近时间”约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略的数据,是没什么差别的。唯一不同的是,热库,会定时的删除旧的数据。

双写

双写是最简单,但是又最不靠谱的方案。结构如下图。

但是注意,操作步骤1约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略、2,涉及到分布式事务,需要同时保证两个库的写入成功。

这就让事情变的麻烦了一些。作为一个吃过无数次事务问题的亏的人,不会重蹈这样的覆辙。

所以,这种方案,直接pass。

走消息

细心的同学应该发现了上图的优化点,通过引入一个叫做消息队列的东西,就可以把分布式事务这座大山给绕过去,只保证最终一致性即可。

多么美好的设想。理想约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略很丰满,现实很骨感。由皮皮虾的做法于冷热分离涉及到非常多的数据表,需要修改不可预知的业务代码,遭到了大家的一致反对。

此方案无疾而终。

直接看图,变了两根线而已。

使用binlog

有的同学可能已经憋不住了:为什么不用binlog?接下来我们就谈下约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略这种方案。

不可否认,这是种非常优雅的方式。数据只需要写入热库就可以了,通过数据订阅的方式,增量的将数据写入到冷库。

但是等等。我们的定时任务,删除数据的时候,同样也要产生binlog。如何区别数据的删除,是定时任务产生的,还是正常的业务产生?

还好,xjjdog知晓一个非常隐秘的方式去操作。

对对对,就是下面的过程。

set session sql_log_bin=0;//optset session sql_log_bi岩本彻三n=1;

binlog可以设置session级别的,也就是在此sessi视频转换器on中操作的语句,并不会产生binlog。

这样,我们在定时任务执行时,先关闭binlog,然后,执行删除语句,然后,重新恢复binlog。这些删除的数据,就不会通过canal同步到冷库中了。

万万没想到

mmp?

为什么不支持呢?为什么呢?容我小心翼翼的猜想一下。你的rds啊,有可能在和别人在共用一个实例呢。

其实,除了rds的限制,此方案还存在一个bug。比如热库有冷热分离的时候。想想为甚么吧。

标记清除

头孢拉定胶囊

得了,xjjdog只能曲线救国了。用最2的方式完成这个操蛋的功能。

标记清除。这四个醒目的大字,让人不由自主的想腾讯招聘到jvm的垃圾回收算法。

原理其实也类似,步骤也是莫镐廉一分为二。

第一、标记阶段

给每一张数据表,都加一个叫做mark2Del字段。然后,通过定时,标记所有要过期(也就是要放入冷库的数据)。

第二、清除阶段

在下一次定时来临时,将上次标记要删除的数据,逐条搬迁到冷库。搬迁完毕后,进行下一轮标记。

此方案非常简单,但有个致命弱点。由于所有的库表,都是老表,都需要增加一个叫做mark2Del的字段,甚是麻烦。

然而,上面的介绍,只是解决了数据的删除,并没有解决数据的同步。

最终方案

结合以上的描述,以及环境的限制。我们选择了使用binlog+标记清除的方式。

标记清除负责删除桂平天气数据。

binlog负责增量同步数据。只是,在这个同步逻辑中,多了一个判断,如果mark2Del的值被设置成了true,则忽略此binlog。

约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略

也就是说,我们强行给每条删除的记录,追加了一个判断标志。

这样,系统终于跑起来了。

End

上文描述的,是mysql到mysql之间的赖兴发冷热分离。

但如果,我想要做一个分层眉山天气预报的数据仓库。

第一层,是热库。

第二层,是冷库。

第三层,是存档库,可能是druid这种大数据存储。

该如何设计?

本文不做过多介绍。架构迷途的难点不在结果,而在于过程。

你看起来很挫的方案,总有它背后的故事,尝试约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略着去理解,大有裨益。

除非它是真的挫。不过,这不也是你的约会大作战小说,技能共享: 数据冷热别离,纪念碑谷攻略机会么?

妄想学生会
石豇豆

转载请保留出处和链接!

本文链接:http://www.ununbox.com/articles/1522.html

文章底部广告(PC版)
文章底部广告(移动版)
百度分享获取地址:http://share.baidu.com/
百度推荐获取地址:http://tuijian.baidu.com/,百度推荐可能会有一些未知的问题,使用中有任何问题请直接联系百度官方客服!
评论框上方广告(PC版)
评论框上方广告(移动版)
推荐阅读
11月16日

洪晃,双汇集团“没了”!万隆行将退休,为下一任掌舵人扫清妨碍,形容时间过得快的句子

发布 : | 分类 : 科研发现 | 评论 : 0人 | 浏览 : 222次

导读:“此举可能也意味着万隆即将退休,为下一任掌舵人扫清障碍。”文/《财经国家周刊》记者 王先知、实习生 张艺璇双汇集团注入上市公司一事终于尘埃落定。9月25日,双汇发展(24.40,+1.67%)(000895....

标签 :
11月14日

汽车品牌标志大全,95后小伙1万5下手弯道之王马自达6 拿来练手很是高兴 看下值不值,儿童发型

发布 : | 分类 : 科研发现 | 评论 : 0人 | 浏览 : 128次

马自达6一直是同级别同价位最具运动最具操控性的中级车轿跑,老款马6的外观就是放到现在也不过时,车身充满了时尚感,后来的马六升级为睿翼,再后来更名为阿特兹,虽然老马六已经停产但是江湖上一直还流传着它的传说,操控性和底盘一直被人们津津乐道,今天咱们就去帮一个95后小兄弟看一台07年的...

标签 :