互联网一致性架构设计 -- 冗余表数据一致性
需求分析
互联网很多业务场景的数据量很大,此时数据库架构要进行水平切分,水平切分会有一个patition key,通过patition key的查询能够直接定位到库,但是非patition key上的查询可能就需要扫描多个库了。
例如订单表,业务上对用户和商家都有订单查询需求:
Order(oid, info_detail)
T(buyer_id, seller_id, oid)
1. 如果用buyer_id来分库,seller_id的查询就需要扫描多库。
2. 如果用seller_id来分库,buyer_id的查询就需要扫描多库。
解决方法:为了做到高吞吐量低延时的查询,往往使用“数据冗余”的方式来实现,就是文章标题里说的“冗余表”:
T1(buyer_id, seller_id, oid)
T2(seller_id, buyer_id, oid)
同一个数据,冗余两份
一份以buyer_id来分库,满足买家的查询需求
一份以seller_id来分库,满足卖家的查询需求
冗余表的实现方案
方法一:服务同步写
- 业务方调用服务,新增数据
- 服务先插入T1数据
- 服务再插入T2数据
- 服务返回业务方新增数据成功
优点
- 不复杂,服务层由单次写,变两次写
- 数据一致性相对较高(因为双写成功才返回)
缺点
- 请求的处理时间增加(要插入次,时间加倍)
- 数据仍可能不一致,例如第二步写入T1完成后服务重启,则数据不会写入T2
- 如果系统对处理时间比较敏感,不考虑使用。
方法二:服务异步写
数据的双写并不再由服务来完成,服务层异步发出一个消息,通过消息总线发送给一个专门的数据复制服务来写入冗余数据。
- 业务方调用服务,新增数据
- 服务先插入T1数据
- 服务向消息总线发送一个异步消息(发出即可,不用等返回,通常很快就能完成)
- 服务返回业务方新增数据成功
- 消息总线将消息投递给数据同步中心
- 数据同步中心插入T2数据
优点
- 请求处理时间短(只插入1次)
缺点
- 系统的复杂性增加了,多引入了一个组件(消息总线)和一个服务(专用的数据复制服务)
- 因为返回业务线数据插入成功时,数据还不一定插入到T2中,因此数据有一个不一致时间窗口(这个窗口很短,最终是一致的)
- 在消息总线丢失消息时,冗余表数据会不一致
- 如果想解除“数据冗余”对系统的耦合,建议使用下面方案
方法三:线下异步写
数据的双写不再由服务层来完成,而是由线下的一个服务或者任务来完成。
- 业务方调用服务,新增数据
- 服务先插入T1数据
- 服务返回业务方新增数据成功
- 数据会被写入到数据库的log中
- 线下服务或者任务读取数据库的log
- 线下服务或者任务插入T2数据
优点
- 数据双写与业务完全解耦
- 请求处理时间短(只插入1次)
缺点
- 返回业务线数据插入成功时,数据还不一定插入到T2中,因此数据有一个不一致时间窗口(这个窗口很短,最终是一致的)
- 数据的一致性依赖于线下服务或者任务的可靠性
问题
上述三种方案各有优缺点,但不管哪种方案,都会面临“究竟先写T1还是先写T2”的问题?这该怎么办呢?
究竟先写正表还是反表
解决方法:谁先做对业务的影响较小,就谁先执行。
以上文的订单生成业务为例,buyer和seller冗余表都需要插入数据:
- T1(buyer_id, seller_id, oid)
- T2(seller_id, buyer_id, oid)
1. 用户下单时,如果“先插入buyer表T1,再插入seller冗余表T2”,当第一步成功、第二步失败时,出现的业务影响是“买家能看到自己的订单,卖家看不到推送的订单”
2. 相反,如果“先插入seller表T2,再插入buyer冗余表T1”,当第一步成功、第二步失败时,出现的业务影响是“卖家能看到推送的订单,卖家看不到自己的订单”
3. 由于这个生成订单的动作是买家发起的,买家如果看不到订单,会觉得非常奇怪,并且无法支付以推动订单状态的流转,此时即使卖家看到有人下单也是没有意义的。
4. 因此,在此例中,应该先插入buyer表T1,再插入seller表T2。
如何保证数据的一致性
方法一:线下扫面正反冗余表全部数据
线下启动一个离线的扫描工具,不停的比对正表T1和反表T2,如果发现数据不一致,就进行补偿修复。
优点
- 比较简单,开发代价小
- 线上服务无需修改,修复工具与线上服务解耦
缺点
- 扫描效率低,会扫描大量的“已经能够保证一致”的数据
- 由于扫描的数据量大,扫描一轮的时间比较长,即数据如果不一致,不一致的时间窗口比较长
方法二:线下扫描增量数据
每次只扫描增量的日志数据,就能够极大提高效率,缩短数据不一致的时间窗口。当然,我们还是需要一个离线的扫描工具,不停的比对日志log1和日志log2,如果发现数据不一致,就进行补偿修复。
- 写入正表T1
- 第一步成功后,写入日志log1
- 写入反表T2
- 第二步成功后,写入日志log2
优点
- 虽比方法一复杂,但仍然是比较简单的
- 数据扫描效率高,只扫描增量数据
缺点
- 线上服务略有修改(代价不高,多写了2条日志)
- 虽然比方法一更实时,但时效性还是不高,不一致窗口取决于扫描的周期
- 依然不是实时的,所以要看下一个方案
方法三:实时线上“消息对”检测
这次不是写日志了,而是向消息总线发送消息;这次不是需要一个周期扫描的离线工具了,而是一个实时订阅消息的服务不停的收消息。
假设正常情况下,msg1和msg2的接收时间应该在3s以内,如果检测服务在收到msg1后没有收到msg2,就尝试检测数据的一致性,不一致时进行补偿修复。
优点
- 效率高
- 实时性高
缺点
- 方案比较复杂,上线引入了消息总线这个组件
- 线下多了一个订阅总线的检测服务
相关推荐
通过HSI(Hot Standby Interface)模块实现数据同步,确保两台CPU间的数据一致性。当主CPU出现故障时,HSI会触发切换,备用CPU立即接管运行。 4. **冗余功能** - **故障安全**:S7-400H支持故障安全功能,可以在...
S7-1500RH作为S7-1500系列PLC的一个高级版本,它包含了冗余(Redundant)和高性能(High-performance)两个特点,尤其适用于对控制系统的连续运行和数据一致性有极高要求的场合。 冗余系统是工业自动化中的一种安全...
本文将围绕杨海朝先生的个人简介,探讨在新浪背景下,MySQL数据库如何实现扩展性,以及复制结构、Sharding策略、高可用性(HA)和跨IDC(互联网数据中心)的设计案例。 首先,可扩展性在数据库架构设计中至关重要。...
用户可以学习如何设置和配置冗余模块,理解心跳信号的原理,以及如何处理故障恢复后的数据一致性问题。 在S7-414H中,冗余功能的实现依赖于专门的硬件组件,如IM153模块,它提供了冗余控制器间的物理连接。同时,...
- **数据同步**:主备站点通过特定的通讯接口进行数据同步,确保数据一致性。 ##### 1.3 程序结构 S7-300软冗余系统的用户程序主要由以下几个部分组成: - **非冗余程序段**:通常放置于OB1中,这部分程序无论...
2. **范式原则深层次应用**:深入理解并应用范式理论,优化数据库设计,减少冗余和提高数据一致性。 3. **数据架构与标准设计**:建立统一的数据架构标准,确保跨系统数据的兼容性和互操作性。 4. **设计与构建...
【互联网数据库架构设计最佳实践】 ...以上就是互联网数据库架构设计的一些最佳实践,这些策略和方法旨在平衡系统的可用性、性能和一致性,同时具备良好的扩展性,以适应不断增长的数据量和业务需求。
锁机制保证了数据的一致性,但也可能导致死锁,理解并优化锁的使用是必要的。缓存策略,如使用Memcached或Redis进行数据缓存,可以显著减少数据库的访问压力。日志管理则关乎数据安全和恢复,而性能监控工具如pt-...
通过比较两个DSP处理结果的一致性,可以有效检测和隔离潜在的错误或数据不一致问题。这种机制不仅提升了单个数据点的精确度,而且进一步增强了整个系统的稳定性和可靠性。 在深入理解双DSP冗余惯性平台控制器的设计...
在设计互联网数据库架构时,首要考虑的是系统的可用性和读写性能,同时也要处理一致性问题,确保扩展性和应对海量数据的处理能力。以下是对这些关键点的详细解析: 1. **可用性设计** - 通过复制和冗余来提高系统...
然而,分布式独立冗余存储也面临挑战,如网络延迟、数据一致性、管理和监控复杂性等。为了克服这些问题,系统设计者需要采用高级的网络协议、分布式锁机制、数据复制策略等技术手段。 总结来说,"行业分类-设备装置...
总的来说,大数据分析平台的数据交换层架构设计需要综合考虑性能、准确性、安全性和可扩展性等多个方面。通过合理配置各个组件和流程,可以构建一个高效、可靠且灵活的数据交换体系,为企业的数据分析提供坚实的基础...
通过对现有业务流程的深入理解,数据架构的设计将确保数据的一致性、完整性和可用性,从而支持集团的战略决策和日常运营。 ##### 1.2 设计目标 数据架构的设计目标主要包括: - **业务支撑**:确保数据架构能够...
4. **并发控制**:利用乐观锁、向量时钟等机制保证数据的一致性和完整性。 5. **计算型和IO型任务的区分处理**:针对不同类型的任务采用不同的执行策略,如单线程模型、多线程模型等。 ### 总结 通过对“空间换时间...
3. **故障切换机制**:详细解释当主系统出现故障时,如何自动切换到备用系统,以及在切换过程中如何保持数据的一致性。 4. **案例分析**:提供实际的工程应用案例,展示软冗余在不同行业的应用,如化工、制药、能源...
2. 数据架构:描述了企业数据的结构、类型和管理方式,确保数据的一致性、准确性和可用性。 3. 应用架构:确定支持业务运作的应用系统,包括软件系统、接口和数据流等。 4. 技术架构:涵盖了硬件、网络、操作系统、...
2. **同步机制**:为了确保数据的一致性,冗余PLC系统需要一个高精度的同步机制。西门子的系统通常采用Heartbeat机制,实时监控两台PLC的状态并保持数据同步。 3. **故障检测与切换**:当主站之一发生故障时,系统...
- **一致性**:确保数据在整个企业内的统一性和一致性,避免数据孤岛。 - **可扩展性**:设计应考虑到未来的业务发展和数据增长,留有足够的扩展空间。 - **安全性**:保护数据免受未经授权的访问和篡改,确保...
### 数据架构设计——100亿数据1万属性下的高效解决方案 #### 一、背景与业务介绍 在当今数字化时代,随着数据量的急剧增长,企业和组织面临着前所未有的挑战,尤其是在处理大规模数据集时。本篇文章针对的是一个...
数据中心网络采用冗余设计,实现网络设备、线路的冗余备份以保证较高的可靠性。 数据中心建设架构设计全文共18页,当前为第2页。数据中心建设架构设计全文共18页,当前为第2页。1.2 互联网区网络 数据中心建设架构...