如果同时将数据写入两个数据库,是不是就打成了同步备份的效果?

2015-02-26 19:14:52 +08:00
 fkbd
首先将 数据 同时写入A和B数据库
然后在读取时 只读取A数据库
这样做是不是有什么弊端,所以基本没看到有人这么做呢?

相比用其他的软件,感觉这样的方法简单暴力的多。
5008 次点击
所在节点    奇思妙想
23 条回复
kzzhr
2015-02-27 11:56:54 +08:00
修改数据库 和 备份数据库 这是两个功能
为什么要放在一起。。
分层啊分层
duzhe0
2015-02-27 18:05:31 +08:00
这样做肯定不好。
首先是数据库消耗时间double,你现在可能没有遇到,某些情况下这是不可接受的。
其次是一致性问题。如果没有出错,两个库是完全一致的,看上去很美好。但程序的世界里, 我们得考虑所有可能发生的事情。在第一次写入完成后发生了程序崩溃,系统崩溃,机器断电,网络中断等等问题而导致第二次写入没有成功,就导致了两个库的差异。问题的关键在于, 你这种方案处理这种情况非常麻烦,基本靠人工分析和处理,非常耽误时间。
再次,这样的设计会导致可用性降低。假设单个数据库实例的故障率是P,如果我们只操作一个数据库,那由数据库故障导致的系统不可用概率就是P。这种简单写两个库的方案, 任何一个库故障都会导致系统不可用,其概率是1-(1-P)^2 约等于2P。

相比而言,在存储层去做数据备份和容灾(比如一个非常简单的主从备份),都不会带来这些问题。
shendancan
2015-03-04 09:02:33 +08:00
都这样操作,备份软件就没有市场和存在的必要了,也没必要卖十几二十万了!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://tanronggui.xyz/t/173011

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX