0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

介绍4种常用的MySQL同步ES方案

jf_ro2CN3Fa 来源:楼仔 2023-11-20 10:45 次阅读

1. 前言

在实际项目开发中,我们经常将 MySQL 作为业务数据库,ES 作为查询数据库,用来实现读写分离,缓解 MySQL 数据库的查询压力,应对海量数据的复杂查询。

这其中有一个很重要的问题,就是如何实现 MySQL 数据库和 ES 的数据同步,今天和大家聊聊 MySQL 和 ES 数据同步的各种方案。

我们先看看下面 4 种常用的数据同步方案。

2. 数据同步方案

2.1 同步双写

这是一种最为简单的方式,在将数据写到 MySQL 时,同时将数据写到 ES。

fd5f81fc-8748-11ee-939d-92fbcf53809c.png

优点:

业务逻辑简单;

实时性高。

缺点:

硬编码,有需要写入 MySQL 的地方都需要添加写入 ES 的代码;

业务强耦合

存在双写失败丢数据风险;

性能较差,本来 MySQL 的性能不是很高,再加一个 ES,系统的性能必然会下降。

2.2 异步双写

针对多数据源写入的场景,可以借助 MQ 实现异步的多源写入。

fd7a5838-8748-11ee-939d-92fbcf53809c.png

优点:

性能高;

不易出现数据丢失问题,主要基于 MQ 消息的消费保障机制,比如 ES 宕机或者写入失败,还能重新消费 MQ 消息;

多源写入之间相互隔离,便于扩展更多的数据源写入。

缺点:

硬编码问题,接入新的数据源需要实现新的消费者代码;

系统复杂度增加,引入了消息中间件;

MQ是异步消费模型,用户写入的数据不一定可以马上看到,造成延时。

2.3 基于 SQL 抽取

上面两种方案中都存在硬编码问题,代码的侵入性太强,如果对实时性要求不高的情况下,可以考虑用定时器来处理:

数据库的相关表中增加一个字段为 timestamp 的字段,任何 CURD 操作都会导致该字段的时间发生变化;

原来程序中的 CURD 操作不做任何变化;

增加一个定时器程序,让该程序按一定的时间周期扫描指定的表,把该时间段内发生变化的数据提取出来;

逐条写入到 ES 中。

fd8737d8-8748-11ee-939d-92fbcf53809c.png

优点:

不改变原来代码,没有侵入性、没有硬编码;

没有业务强耦合,不改变原来程序的性能;

Worker 代码编写简单不需要考虑增删改查。

缺点:

时效性较差,由于是采用定时器根据固定频率查询表来同步数据,尽管将同步周期设置到秒级,也还是会存在一定时间的延迟;

对数据库有一定的轮询压力,一种改进方法是将轮询放到压力不大的从库上。

经典方案:借助 Logstash 实现数据同步,其底层实现原理就是根据配置定期使用 SQL 查询新增的数据写入 ES 中,实现数据的增量同步。

2.4 基于 Binlog 实时同步

上面三种方案要么有代码侵入,要么有硬编码,要么有延迟,那么有没有一种方案既能保证数据同步的实时性又没有代入侵入呢?

当然有,可以利用 MySQL 的 Binlog 来进行同步。

fd981472-8748-11ee-939d-92fbcf53809c.png

具体步骤如下:

读取 MySQL 的 Binlog 日志,获取指定表的日志信息

将读取的信息转为 MQ;

编写一个 MQ 消费程序;

不断消费 MQ,每消费完一条消息,将消息写入到 ES 中。

优点:

没有代码侵入、没有硬编码;

原有系统不需要任何变化,没有感知;

性能高;

业务解耦,不需要关注原来系统的业务逻辑。

缺点:

构建 Binlog 系统复杂;

如果采用 MQ 消费解析的 Binlog 信息,也会像方案二一样存在 MQ 延时的风险。

3. 数据迁移工具选型

对于上面 4 种数据同步方案,“基于 Binlog 实时同步”方案是目前最常用的,也诞生了很多优秀的数据迁移工具,这里主要对这些迁移工具进行介绍。

这些数据迁移工具,很多都是基于 Binlog 订阅的方式实现,模拟一个 MySQL Slave 订阅 Binlog 日志,从而实现 CDC (Change Data Capture),将已提交的更改发送到下游,包括 INSERT、DELETE、UPDATE。

至于如何伪装?大家需要先了解 MySQL 的主从复制原理,需要学习这块知识的同学,可以看我之前写的高并发教程,里面有详细讲解。

3.1 Cannel

基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持 MySQL。

Canal 原理就是伪装成 MySQL 的从节点,从而订阅 master 节点的 Binlog 日志,主要流程为:

Canal 服务端向 MySQL 的 master 节点传输 dump 协议;

MySQL 的 master 节点接收到 dump 请求后推送 Binlog 日志给 Canal 服务端,解析 Binlog 对象(原始为 byte 流)转成 Json 格式;

Canal 客户端通过 TCP 协议或 MQ 形式监听 Canal 服务端,同步数据到 ES。

fda32ec0-8748-11ee-939d-92fbcf53809c.png

下面是 Cannel 执行的核心流程,其中 Binlog Parser 主要负责 Binlog 的提取、解析和推送,EventSink 负责数据的过滤 、路由和加工,仅作了解即可。

fdc3d328-8748-11ee-939d-92fbcf53809c.png

3.2 阿里云 DTS

数据传输服务 DTS(Data Transmission Service)支持 RDBMS、NoSQL、OLAP 等多种数据源之间的数据传输。

它提供了数据迁移、实时数据订阅及数据实时同步等多种数据传输方式。相对于第三方数据流工具,DTS 提供丰富多样、高性能、高安全可靠的传输链路,同时它提供了诸多便利功能,极大方便了传输链路的创建及管理。

特点:

多数据源:支持 RDBMS、NoSQL、OLAP 等多种数据源间的数据传输;

多传输方式:支持多种传输方式,包括数据迁移、实时数据订阅及数据实时同步;

高性能:底层采用了多种性能优化措施,全量数据迁移高峰期时性能可以达到70MB/s,20万的TPS,使用高规格服务器来保证每条迁移或同步链路都能拥有良好的传输性能;

高可用:底层为服务集群,如果集群内任何一个节点宕机或发生故障,控制中心都能够将这个节点上的所有任务快速切换到其他节点上,链路稳定性高;

简单易用:提供可视化管理界面,提供向导式的链路创建流程,用户可以在其控制台简单轻松地创建传输链路;

需要付费。

再看看 DTS 的系统架构。

fdd2349a-8748-11ee-939d-92fbcf53809c.png

高可用:数据传输服务内部每个模块都有主备架构,保证系统高可用。容灾系统实时检测每个节点的健康状况,一旦发现某个节点异常,会将链路快速切换到其他节点。

数据源地址动态适配:对于数据订阅及同步链路,容灾系统还会监测数据源的连接地址切换等变更操作,一旦发现数据源发生连接地址变更,它会动态适配数据源新的连接方式,在数据源变更的情况下,保证链路的稳定性。

3.3 Databus

Databus 是一个低延迟、可靠的、支持事务的、保持一致性的数据变更抓取系统。由 LinkedIn 于 2013 年开源。

Databus 通过挖掘数据库日志的方式,将数据库变更实时、可靠的从数据库拉取出来,业务可以通过定制化 client 实时获取变更并进行其他业务逻辑。

特点:

多数据源:Databus 支持多种数据来源的变更抓取,包括 Oracle 和 MySQL。

可扩展、高度可用:Databus 能扩展到支持数千消费者和事务数据来源,同时保持高度可用性。

事务按序提交:Databus 能保持来源数据库中的事务完整性,并按照事务分组和来源的提交顺寻交付变更事件。

低延迟、支持多种订阅机制:数据源变更完成后,Databus 能在毫秒级内将事务提交给消费者。同时,消费者使用D atabus 中的服务器端过滤功能,可以只获取自己需要的特定数据。

无限回溯:对消费者支持无限回溯能力,例如当消费者需要产生数据的完整拷贝时,它不会对数据库产生任何额外负担。当消费者的数据大大落后于来源数据库时,也可以使用该功能。

再看看 Databus 的系统架构。

Databus 由 Relays、bootstrap 服务和 Client lib 等组成,Bootstrap 服务中包括 Bootstrap Producer 和 Bootstrap Server。

fde5760e-8748-11ee-939d-92fbcf53809c.png

快速变化的消费者直接从 Relay 中取事件;

如果一个消费者的数据更新大幅落后,它要的数据就不在 Relay 的日志中,而是需要请求 Bootstrap 服务,返回的将会是自消费者上次处理变更之后的所有数据变更快照。

3.4 其它

Flink

有界数据流和无界数据流上进行有状态计算分布式处理引擎和框架。

CloudCanal

数据同步迁移系统,商业产品

Maxwell

使用简单,直接将数据变更输出为json字符串,不需要再编写客户端。

DRD

阿里巴巴集团自主研发的分布式数据库中间件产品,专注于解决单机关系型数据库扩展性问题,具备轻量(无状态)、灵活、稳定、高效等特性。

yugong

帮助用户完成从 Oracle 数据迁移到 MySQL。

4. 后记

通过这篇文章,让你知道 MySQL 和其它多维数据的同步方案,以及常用的数据迁移工具,帮助你更好选型。






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 定时器
    +关注

    关注

    23

    文章

    3147

    浏览量

    112038
  • SQL
    SQL
    +关注

    关注

    1

    文章

    738

    浏览量

    43461
  • MySQL
    +关注

    关注

    1

    文章

    775

    浏览量

    26005
  • MYSQL数据库
    +关注

    关注

    0

    文章

    95

    浏览量

    9277

原文标题:4 种 MySQL 同步 ES 方案,yyds!

文章出处:【微信号:芋道源码,微信公众号:芋道源码】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Linux中常用MySQL运维脚本

    在Linux中,使用MySQL进行常见的运维任务时,可以编写一些脚本来简化操作。以下是一些常用MySQL运维脚本,希望对你的工作有所帮助。
    发表于 09-07 09:49 352次阅读

    FPGA 设计的四常用思想与技巧

    FPGA 设计的四常用思想与技巧FPGA设计的四常用思想与技巧 讨论的四常用FPGA/C
    发表于 08-11 10:30

    0基础学Mysql:mysql入门视频教程!

    的性能调优技术掌握基于MySQL的架构设计方案课程目录:第1节 MySQL课程介绍MySQL的基础概念(1)第2节
    发表于 07-08 10:51

    MySql常用操作整理

    MySql——基本知识整理
    发表于 04-09 13:35

    MySQL及其常用命令介绍

    MySQL 数据库常用命令
    发表于 04-12 13:19

    linux配置mysql的两方式

    方式:a、$ find / -name mysql–print 查看是否有mysql文件夹b、$ netstat -a –n 查看是否打开3306端口
    发表于 07-26 07:46

    mysql数据库优化方案

    MySQL千万级大表优化解决方案
    发表于 08-19 12:18

    Canal是如何同步mysql的增量数据的

    Canal是什么?Canal的工作原理是什么?Canal是如何同步mysql的增量数据的?
    发表于 10-27 07:41

    mysql数据库同步原理

    了数据库的访问压力,提升整个系统的性能和可用性,降低了大访问量引发数据库宕机的故障率。 binlog简介 MySQL主从同步是基于binlog文件主从复制实现,为了更好的理解主从同步过程,这里简单
    发表于 09-28 11:49 0次下载
    <b class='flag-5'>mysql</b>数据库<b class='flag-5'>同步</b>原理

    Mysql主从同步的实现原理

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL
    发表于 12-26 15:56 2854次阅读
    <b class='flag-5'>Mysql</b>主从<b class='flag-5'>同步</b>的实现原理

    深度解读ES+Redis+MySQL的高可用架构设计

    我们有两个机房,分别是机房 A 和机房 B。我们把 ES 主集群部署在机房 A,把 ES 备集群部署在机房 B。会员系统的读写都在 ES 主集群,通过 MQ 将数据同步
    的头像 发表于 06-01 10:09 464次阅读
    深度解读<b class='flag-5'>ES+Redis+MySQL</b>的高可用架构设计

    MySQL运维常用脚本

    进入MySQL:启动MySQL Command Line Client(MySQL的DOS界面),直接输入安装时的密码即可。此时的提示符是:mysql>
    的头像 发表于 07-29 11:23 391次阅读

    MySQLES的4种常用数据同步方案

    如何实现 MySQL 数据库和 ES 的数据同步,今天和大家聊聊 MySQLES 数据同步
    发表于 08-09 11:36 367次阅读
    <b class='flag-5'>MySQL</b>到<b class='flag-5'>ES</b>的4种<b class='flag-5'>常用</b>数据<b class='flag-5'>同步</b><b class='flag-5'>方案</b>

    mysql增删改查语句以及常用方法

    MySQL是一种热门的关系型数据库管理系统,广泛用于各种Web应用程序和企业级应用程序中。本文将详细介绍MySQL中的增删改查语句以及常用方法。 一、增加数据 在
    的头像 发表于 11-16 15:36 607次阅读

    MySQL常用语句

    MySQL是一个关系型数据库管理系统,广泛应用于Web应用程序的开发以及数据管理领域。在使用MySQL时,有一些常用的语句可以帮助我们进行数据的操作和管理。接下来,我将详细介绍
    的头像 发表于 11-21 11:11 271次阅读