【系统架构】系统架构设计之数据同步策略

news2025/1/15 13:03:50

文章目录

  • 一、介绍
    • 1.1、分布式系统中的数据同步定义
    • 1.2、为何数据同步如此关键
    • 1.3、数据同步策略简介
  • 二、为什么需要数据同步
    • 2.1、提高系统可用性
    • 2.2、备份与灾难恢复
    • 2.3、提高性能
    • 2.4、考虑地理位置(如使用CDN)
  • 三、同步备份
    • 3.1、定义和概述
    • 3.2、工作原理
    • 3.3、优点和缺点
  • 四、异步备份
    • 4.1、定义和概述
    • 4.2、工作原理
    • 4.3、优缺点
  • 五、半同步备份
    • 5.1、定义和概述
    • 5.2、工作原理
    • 5.3、优缺点
  • 六、选择合适的备份策略
    • 6.1、需要考虑的因素
    • 6.2、策略比较
  • 七、结论
    • 7.1、关键点总结
    • 7.2、对系统设计的影响

一、介绍

1.1、分布式系统中的数据同步定义

数据同步犹如合唱团里的B角歌手。设想你正在观看音乐会,突然,主唱失声。如果有B角歌手,那么音乐会仍能继续。在计算机领域,数据同步就是对数据进行备份。若系统的某个部分出现问题,其它部分还能继续运行。这就像一个保险,确保信息始终可获取,不论出现何种意外。

1.2、为何数据同步如此关键

试想一下,你手机中那张最珍爱的照片。再想象,如果它永远消失了。那种感觉很难受,对吧?这就是我们常常在多处保存宝贵记忆的原因。同样,各种企业和组织也要确保他们的关键数据得到保护。数据同步犹如多处备份你的珍贵照片,它确保数据始终安全并且随时可用。不论是顾客订单、医疗记录还是学生成绩,数据同步保证重要信息不会遗失。

1.3、数据同步策略简介

保存照片有多种方式,比如在手机、电脑或者云上。在计算机系统里,数据同步也有各种方法,这些被称为数据同步策略。有的方法速度快但可能有丢失数据的风险,有的则较慢但更为稳妥。选择合适的策略就如同为特定任务挑选合适的工具,根据实际需求和所看重的因素来决定。正确地选择数据同步策略对于系统设计至关重要。本文将探讨三大主要策略:同步、异步和半同步备份,详细介绍它们的操作原理、优势以及使用场景。

二、为什么需要数据同步

2.1、提高系统可用性

试想你正在看你最爱的电视剧,突然屏幕一片空白。心情会很差,对吗?在计算机世界里,数据的可用性就像是这部电视剧,你希望它始终在那里。如果系统的一部分出现问题,数据同步确保其他部分能够继续工作。这就像电视上有多个备选频道播放同一部剧。一个频道出了问题,你可以换另一个。

2.2、备份与灾难恢复

你可以把数据同步想象成是一艘船上的救生艇。当出现重大事故时,它可以挽救局势。在IT领域,各种意外都可能发生,如停电、硬件损坏或自然灾害。数据同步好比时刻待命的救生艇。当事故发生,可以依赖数据的备份来快速恢复服务。

2.3、提高性能

你是否曾在商店排队等待很久?如果有更多的服务窗口或收银台,整体效率会更高,对吧?数据同步的原理也是如此。通过在不同地方存储数据的备份,可以更快地响应用户请求,类似于增开服务窗口,使得服务变得更加高效。

2.4、考虑地理位置(如使用CDN)

如果你在上海,但要从深圳的服务器那里请求数据,响应自然会慢一些。但如果数据在上海的服务器上有备份,那么访问就迅速得多。数据同步使数据更接近用户的物理位置,减少了访问延迟,这在为全球用户提供服务时非常重要。这好比在每个城市都有分店,确保每位顾客都能得到快速的服务。

三、同步备份

3.1、定义和概述

同步备份就好比一队消防员共同作战。当发生火灾时,他们会同时出动,确保一切都在控制之下才撤离。在计算机术语中,同步备份意味着当某个地方的数据更新后,其他所有地方的数据也会立即得到更新。系统的所有部分协同工作,确保每一个数据从节点都是一致的。这是保持所有数据完美同步的方式。
在这里插入图片描述

3.2、工作原理

主节点操作:想象一下一艘船的船长正在发号施令。队长(或主节点)负责,当需要做某事时,他们确保每个人都知道。在同步备份中,主节点就像船长一样,指挥着数据如何更新。它是启动这一过程并确保一切顺利进行的人。

从节点操作:船上的船员就像同步备份中的从节点。他们听从船长的命令,确保一切顺利。当主节点要求更新数据时,从节点会立即执行。他们一起工作,确保数据的每个从节点都完全相同。

确认过程:一旦船员遵循了船长的命令,他们就会向船长报告,让船长知道工作已经完成。在同步备份中,从节点会向主节点发送确认信息。就像竖起大拇指,表示“一切都好!” 这可确保一切同步并且过程完整。

3.3、优点和缺点

容错:同步备份就像汽车里有一个备胎。如果出现问题,您可以随时进行备份。由于所有数据从节点都是相同的,因此如果其中一部分发生故障,其他部分可以接管。这是确保系统始终可靠并为任何情况做好准备的一种方法。
潜在的阻塞问题:但是,如果你每次开应急灯都要去检查每一个电池是否工作正常,这无疑会造成不必要的延迟。在同步备份中,为了确保每处数据都完全同步,有时会等待所有节点的确认,这可能会造成一些延迟。这种方式更安全,但可能牺牲了一些效率。

四、异步备份

4.1、定义和概述

异步备份有点像我们通过快递发送一个包裹。我们把包裹交给快递公司,但并不能实时地知道包裹是否已经到达接收方。在数据库领域,异步备份是指在主数据库中更新数据后,这些更新会被发送到从数据库,但主数据库不会立即等待从数据库的确认。这样做可以提高数据处理的速度,但同时也增加了数据不一致的风险。
在这里插入图片描述

4.2、工作原理

对客户端的即时响应:在异步备份中,当系统收到你的请求后,它会立即告诉你"已接收",然后让你继续你的其他操作。它不会让你等待所有操作都完成,这完全是为了提高速度和方便性。
对从节点的异步传播:当你放下包裹后,由快递公司来负责送达。你相信它最终会到达目的地。在异步备份中,配送信息更新会发送到系统的其他部分(也就是从节点),这些从节点会在合适的时候进行同步。这就像发送配送信息给大家,你发送后相信每个人都会收到信息。

4.3、优缺点

最大化吞吐量:异步备份就像快速运行的流水线。它确保所有操作都能快速进行,不需要停下来检查每一个小细节。这对于需要同时处理大量请求的系统来说是非常理想方案的。目标是尽可能快地完成任务,即使这意味着要冒一些风险。
数据丢失的可能性:但如果你的快递在配送过程中丢失了怎么办?在异步备份中,存在一些更新可能会丢失或延迟的风险。因此,异步备份虽然快速,但在某些极端情况下,可能会出现数据不一致的情况。

五、半同步备份

5.1、定义和概述

半同步备份就像接力赛跑。一个跑者将接力棒传递给下一个跑者,并且两者都要确保接力棒安全地交接过去后,第一个跑者才会停下。在计算机领域中,半同步备份结合了我们之前提到的两种方法。它确保部分更新在继续进行之前是安全的,但不是全部更新。这是一种平衡的方式,就像走钢丝一样。它旨在兼顾两种方法的优势。
在这里插入图片描述

5.2、工作原理

同步备份到一部分从节点:想象一下,你把一个秘密告诉了几个亲密的朋友,并请他们转告给其他人。在你离开之前,你要确保他们完全明白了。在半同步备份中,一部分从节点会立即得到更新,并且系统会确认它们是正确的。这就像有一个安全网,但不是一个完整的安全网。

异步备份到其他从节点:告诉亲密的朋友秘密后,你相信他们会告诉其他人。你不会检查他们是否真的这样做了。在半同步备份中,剩余的更新会在不进行二次检查的情况下发送出去。这就像播撒种子,相信雨水会浇灌它们。你尽了自己的责任,然后放手。

5.3、优缺点

确保数据持久性:半同步备份就像用一些强大的支柱和一些较弱的支柱建造一座桥。强大的支柱确保桥不会倒塌,而较弱的支柱则增加了一些灵活性。这种方法确保了最重要的部分是安全的,同时不会减慢整个过程。这是一种谨慎的方式。

对吞吐量的边界影响:但如果你想让桥非常坚固,或者非常灵活呢?半同步备份可能对这两者都不完美。它就像是一场谈判中的妥协。每个人都能得到一些东西,但没有人能得到所有东西。它可能会稍微减慢速度,或者可能不如你希望的那么安全。这是一种平衡的方法,这意味着需要做一些权衡。

六、选择合适的备份策略

6.1、需要考虑的因素

选择正确的备份策略就像为特殊场合选择合适的服装一样。您必须考虑天气、事件类型以及您感到舒适的环境。在计算机世界中,您需要考虑数据的重要性、访问数据的速度以及安全性等因素你需要。这是为了找到适合您具体情况的产品。

  • 数据的关键性:某些数据极为重要,你希望它们始终安全,就如同家中的珍贵物品。而有些数据的重要性较低,比如临时文件。确定数据的重要性有助于你选择合适的备份策略。
  • 一致性需求:在数据库中,保持数据一致性意味着确保所有数据的从节点都是最新和准确的。高一致性需求可能会指引你选择同步备份,而较低的一致性需求可能更适合异步备份。
  • 系统吞吐量:吞吐量反映了系统在单位时间内能处理的数据量。高吞吐量需求可能会让你倾向于选择异步备份,因为它通常更快。

6.2、策略比较

同步备份、异步备份和半同步备份都有其优点和缺点。

  • 同步备份就像一双坚固的徒步鞋,安全但有时可能较慢。
  • 异步备份就像跑鞋,速度快但可能不那么保护性。
  • 半同步备份就像休闲运动鞋,两者兼备。

理解这些差异有助于你为旅程选择合适的鞋子。

七、结论

7.1、关键点总结

选择合适的备份策略就像规划一次成功的旅行。你需要知道你的目的地,途中需要的东西,以及如何处理意外的突发情况。同步备份、异步备份和半同步备份,每种方式都有其独特的优点和缺点,就像不同类型的交通工具。理解它们有助于你为旅程选择合适的方式。

7.2、对系统设计的影响

你在备份策略上的选择会产生重大影响,就像为建筑选择正确的基础一样。如果选择得当,一切都会稳固并且运行顺畅。如果选择错误,你可能在未来遇到问题。这是一个需要深思熟虑和充分了解的决策。这关乎建设一个持久且能很好地发挥其功能的系统。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/896965.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot 微人事 职称管理模块(十三)

职称管理前端页面设计 在职称管理页面添加输入框 export default {name: "JobLevelMarna",data(){return{Jl:{name:""}}}}效果图 添加一个下拉框 v-model的值为当前被选中的el-option的 value 属性值 <el-select v-model"Jl.titlelevel" …

C#程序随系统启动例子 - 开源研究系列文章

今天讲讲C#中应用程序随系统启动的例子。 我们知道&#xff0c;应用程序随系统启动&#xff0c;都是直接在操作系统注册表中写入程序的启动参数&#xff0c;这样操作系统在启动的时候就根据启动参数来启动应用程序&#xff0c;而我们要做的就是将程序启动参数写入注册表即可。此…

打印技巧——word中A4排版打印成A3双面对折翻页

在进行会议文件打印时&#xff0c;我们常会遇到需要将A4排版的文件&#xff0c;在A3纸张上进行双面对折翻页打印&#xff0c;本文对设置方式进行介绍&#xff1a; 1、在【布局】选项卡中&#xff0c;点击右下角小箭头&#xff0c;打开页面设置选项卡 1.1在【页边距】中将纸张…

网络安全(黑客)快速入门~

网络安全的学习需要遵守循序渐进&#xff0c;由浅入深。 通常网络安全学习方法有两种&#xff1a; 方法1&#xff1a;先学习编程&#xff0c;然后学习Web渗透及工具使用等&#xff1b; 适用人群&#xff1a;有一定的代码基础的小伙伴 基础部分 基础部分需要学习以下内容&am…

【3Ds Max】车削命令的简单使用(以制作花瓶为例)

简介 在3ds Max中&#xff0c;"车削"&#xff08;Lathe&#xff09;是一种建模命令&#xff0c;用于创建围绕轴线旋转的几何形状。通过车削命令&#xff0c;您可以将一个闭合的平面或曲线几何形状旋转&#xff0c;从而生成一个立体对象。这种方法常用于创建圆柱体、…

易服客工作室:Houzez主题 - 超级房地产WordPress主题/网站

Houzez主题是全球流行的房地产经纪人和公司的WordPress主题。 Houzez Theme是专业设计师创造一流设计的超级灵活起点。它具有您的客户&#xff08;房地产经纪人或公司&#xff09;甚至可能做梦也想不到的功能。 网址&#xff1a;Houzez主题 - 超级房地产WordPress主题/网站 - …

SpringBoot + Vue 微人事项目(第三天)

左边导航菜单制作 element ui添加到Home 把侧栏的标签里面的代码拷贝到标签里面&#xff0c;显示效果如下 左侧导航栏的效果代码 <el-aside width"200px"><el-menu><el-submenu index"1"><template slot"title"><i…

亚信科技AntDB数据库连年入选《中国DBMS市场指南》代表厂商

近日&#xff0c;全球权威ICT研究与顾问咨询公司Gartner发布了2023年《Market Guide for DBMS, China》&#xff08;即“中国DBMS市场指南”&#xff09;&#xff0c;该指南从市场份额、技术创新、研发投入等维度对DBMS供应商进行了调研。亚信科技是领先的数智化全栈能力提供商…

LeetCode150道面试经典题-- 求算数平方根(简单)

1.题目 给你一个非负整数 x &#xff0c;计算并返回 x 的 算术平方根 。 由于返回类型是整数&#xff0c;结果只保留 整数部分 &#xff0c;小数部分将被 舍去 。 注意&#xff1a;不允许使用任何内置指数函数和算符&#xff0c;例如 pow(x, 0.5) 或者 x ** 0.5 。 2.示例 …

8 种主流数据迁移工具技术选型

前言 最近有些小伙伴问我&#xff0c;ETL数据迁移工具该用哪些。 ETL(是Extract-Transform-Load的缩写&#xff0c;即数据抽取、转换、装载的过程)&#xff0c;对于企业应用来说&#xff0c;我们经常会遇到各种数据的处理、转换、迁移的场景。 今天特地给大家汇总了一些目前…

法院人员定位方案

法院人员定位方案可以使用UWB测距技术进行实现。通过UWB测距基站和UWB标签&#xff0c;可以实时准确地定位和跟踪法院人员的位置&#xff0c;提升安全性和工作效率。以下是法院人员定位方案的一般步骤&#xff1a; 1.部署UWB测距基站&#xff1a;在法院内部或需要进行定位的区…

vim 配置环境变量与 JDK 编译器异常

vim 配置环境变量 使用 vim 打开系统中的配置信息&#xff08;不存在将会创建&#xff09;&#xff1a; vim ~/.bash_profile 以配置两个版本 JDK 为例&#xff08;前提是已安装 JDK&#xff09;,使用上述命令打开配置信息&#xff1a; 输入法调成英文&#xff0c;输入 i&…

RocketMQ 5.0 架构解析:如何基于云原生架构支撑多元化场景

作者&#xff1a;隆基 本文将从技术角度了解 RocketMQ 的云原生架构&#xff0c;了解 RocketMQ 如何基于一套统一的架构支撑多元化的场景。 文章主要包含三部分内容。首先介绍 RocketMQ 5.0 的核心概念和架构概览&#xff1b;然后从集群角度出发&#xff0c;从宏观视角学习 R…

mysql in mac学习记录

鉴于有一段时间没有访问mysql了&#xff0c;最近打算在mac 系统上下载mysql 练习一下sql的使用&#xff0c;于是 First, the mysql download https://dev.mysql.com/downloads/mysql/ Second, Mysql install steps Install the software by normally install one software …

ARM M33架构入门

概述 Arm Cortex-M33核心处理器专为需要高效安全或数字信号控制的物联网和嵌入式应用而设计。该处理器具有许多可选功能&#xff0c;包括数字信号处理扩展 (DSP)、用于硬件强制隔离的TrustZone 安全性、内存保护单元 (MPU)和浮点单元 (FPU)。 Cortex-M33 的性能比 Cortex-M…

基于Googlenet深度学习网络的矿物质种类识别matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ............................................................................ Number_of_…

毫米波雷达成像论文阅读笔记: IEEE TPAMI 2023 | CoIR: Compressive Implicit Radar

原始笔记链接&#xff1a;https://mp.weixin.qq.com/s?__bizMzg4MjgxMjgyMg&mid2247486680&idx1&snedf41d4f95395d7294bc958ea68d3a68&chksmcf51be21f826373790bc6d79bcea6eb2cb3d09bb1860bba0af0fd5e60c448ca006976503e460#rd ↑ \uparrow ↑点击上述链接即…

stm32控制蜂鸣器源代码(附带proteus线路图)

说明&#xff1a; 1 PB0输出0时&#xff0c;蜂鸣器发生&#xff1b; 2 蜂鸣器电阻值如果太大会导致电流太小&#xff0c;发不出声音&#xff1b; 3蜂鸣器额定电压需要设置得低一点&#xff0c;可以是2V&#xff0c;但不能高于3V&#xff0c;这更右上角的电阻值有关系&#x…

cdh6.3.2 Flink On Yarn taskmanager任务分配倾斜问题的解决办法

业务场景&#xff1a; Flink On Yarn任务启动 组件版本&#xff1a; CDH&#xff1a;6.3.2 Flink&#xff1a;1.13.2 Hadoop&#xff1a;3.0.0 问题描述&#xff1a; 在使用FLink on Yarn调度过程中&#xff0c;发现taskmanager总是分配在集中的几个节点上&#xff0c;集群…

vscode ssh 远程 gdb 调试

一、点运行与调试&#xff0c;生成launch.json 文件 二、点添加配置&#xff0c;选择GDB 三、修改启动程序路径