《解读NoSQL》——2.8 实践

本节书摘来自异步社区出版社《解读NoSQL》一书中的第2章,第2.8节,作者: 【美】Dan McCreary(丹•麦克雷) , Ann Kelly(安•凯利),更多章节内容可以访问云栖社区“异步社区”公众号查看。

2.8 实践

Sally被委托去帮助一个团队设计一个管理贵宾礼品卡的系统。和银行账户有些类似,持卡人可以为卡充值(存款)、购买(取款)和查看卡的余额。礼品卡的数据会被分区并复制到两个数据中心,一个在美国,一个在欧洲。居住在美国的人们优先分区到美国的数据中心,而欧洲的人们优先分区到欧洲的数据中心。

已知两个数据中心之间的数据传输线路会短时间的中断,大概每年10~20分钟。Sally知道这是一个切分分区的实例,它将考验系统的分区容错性。团队需要决定当数据传输线路故障时全部3个操作(存款、取款和查看余额)是否需要能够继续。

团队决定即使在数据传输线路故障时,存款操作也应该能够继续,这是因为当连接恢复后,存款记录能够更新两个站点的数据。Sally提到如果一个站点不能及时更新另一个站点的余额信息,切分分区可能会造成读取结果不一致。但是团队决定当发生连接故障时,如果请求银行余额,仍然从本地分区返回上次的余额。

对于购买事务,团队决定当发生连接故障时,一旦用户连接到主分区,事务应当继续执行完成。为了限制风险,对于复制分区的取款操作只会限制在一个特定的数额,如100美元。一些报表将会用于查看在网络中断期间,所有分区上的各种取款操作导致了产生错误余额的频率。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值