技术分享 | MySQL 多源复制场景分析

技术分享 | MySQL 多源复制场景分析作者:杨涛涛 今天有客户问起:如何汇总多台 MySQL 数据到一台上? 我回答:可以尝试下 MySQL 的多源复制。 我们知道 MySQL 单主一从,单主多从,或者级联的主从架构我们都见的很多了。但…

作者:杨涛涛

今天有客户问起:如何汇总多台 MySQL 数据到一台上? 我回答:可以尝试下 MySQL 的多源复制。

我们知道 MySQL 单主一从,单主多从,或者级联的主从架构我们都见的很多了。但是多主一从这种使用场景比较少,比如图1:

技术分享 | MySQL 多源复制场景分析

这种架构一般用在以下三类场景

1.备份多台 Server 的数据到一台

如果按照数据切分方向来讲,那就是垂直切分。 比如图 2, 业务 A、B、C、D 是之前拆分好的业务,现在需要把这些拆分好的业务汇总起来备份,那这种需求也很适用于多源复制架构。

实现方法我大概描述下:业务 A、B、C、D 分别位于4台 Server,每台 Server 分别有一个数据库来隔离前端的业务数据,那这样,在从库就能把四台业务的数据全部汇总起来,而不需要做额外的操作。 那没有多源复制之前,要实现这类需求,只能在汇总机器上搭建多个 MySQL 实例,那这样势必会涉及到跨库关联的问题,不但性能急剧下降,管理多个实例也没有单台来的容易。 技术分享 | MySQL 多源复制场景分析

##2.用来聚合前端多个 Server 的分片数据。

同样,按照数据切分方向来讲,属于水平切分。 比如图3,按照年份拆分好的数据,要做一个汇总数据展现, 那这种架构也非常合适。

实现方法稍微复杂些:比如所有 Server 共享同一数据库和表,一般为了开发极端透明,前端配置有分库分表的中间件,比如爱可生的 DBLE。

技术分享 | MySQL 多源复制场景分析

##3. 汇总并合并多个 Server 的数据

第三类和第一种场景类似。不一样的是不仅仅是数据需要汇总到目标端,还得合并这些数据,这就比第一种来的相对复杂些。 比如图4,那这样的需求,是不是也适合多源复制呢? 答案是YES。

技术分享 | MySQL 多源复制场景分析

那具体怎么做呢?

我举个例子,比如下面一张表 A,字段分表为 ID(主键)、F1、F2、F3… 、F100。那按照这样的分法,前端 4 台 Server 的表分别为:

  • A1(ID,F1,F2,…,F25)

  • A2(ID,F26,F27,…,F50)

  • A3(ID,F51,F52,…,F75)

  • A4(ID,F76,F77,…,F100)

那上面几张表的数据如果要合并到表 A,可以建立一个 Event,定时的来给表 A 里插入数据。涉及到的核心 SQL 为:

insert ignore into A select A1.ID,F1,F2,...,F100 
from A1 natural join A2 natural join A3 natural join A4;

代码100分

那我们发现这个和第一个类似,只不过,所有的表最后到复制到了相同的数据库里。

总结下,我上面简单说明了MySQL多源复制的三种常用使用场景,相信对大家有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/11154.html

(0)
上一篇 2022-12-15
下一篇 2022-12-15

相关推荐

  • PostgreSQL笔记「建议收藏」

    PostgreSQL笔记「建议收藏」一.PostgreSQL简介 PostgreSQL数据库一种关系型数据库。是当前世界上最先进的开源关系型数据库。 PostgreSQL使用的是一种客户端/服务器的模式。一次PostgreSQL会话由以

    2023-03-28
    117
  • MySQL中InnoDB和MyISAM引擎的对比

    MySQL中InnoDB和MyISAM引擎的对比目录 索引对比 锁对比 事务对比 并发 全文索引对比 外键 其他 一.索引对比 1.B+树概念 我们这里关注B+树的两个特性: 1. 叶子节点包含数据data(data并不特指数据库中的某一行数据,也

    2023-02-07
    108
  • 实战python:15个项目助力你成为高级开发者

    实战python:15个项目助力你成为高级开发者Python是一种直观、易于学习的编程语言,非常适合初学者。它的开放源代码和丰富的库、框架、工具使得它成为各种领域的开发人员的首选语言。如果您已经具备一些编程基础,那么挑战一些实际项目会有助于提高您的技能和知识,以成为高级开发者。下面我们将介绍15个实战项目,帮助您从新手迈向高手。

    2024-03-07
    31
  • MySQL查询性能优化七种武器之索引下推「建议收藏」

    MySQL查询性能优化七种武器之索引下推「建议收藏」前面已经讲了MySQL的其他查询性能优化方式,没看过可以去了解一下:
    MySQL查询性能优化七种武器之索引潜水
    MySQL查询性能优化七种武器之链路追踪
    今天要讲的是MySQL的另一种查询性能优化方式

    2023-06-01
    98
  • mysql 从库_库管的技能与要求

    mysql 从库_库管的技能与要求想必从库异常中断的情况不在少数,其中报错信息中1032及1062的错误占了不少的比重 错误1032指的是从库中找不到对应行的记录 错误1062指的是主键冲突 遇到此报错时,大多DBA会使用如下方法进行

    2023-02-16
    110
  • TD数据库_数据库和程序如何连接C

    TD数据库_数据库和程序如何连接C云原生数据库 TDSQL-C(Cloud Native Database TDSQL-C,TDSQL-C)是腾讯云自研的新一代高性能高可用的企业级分布式云数据库。融合了传统数据库、云计算与新硬件技术的

    2023-04-21
    111
  • Kylin on Parquet 介绍和快速上手

    Kylin on Parquet 介绍和快速上手Apache Kylin on Apache HBase 方案经过长时间的发展已经比较成熟,但是存在着一定的局限性。因此,Kyligence 推出了 Kylin on Parquet 方案。本文中,K

    2023-02-22
    98
  • Host Arrays – performance gain[通俗易懂]

    Host Arrays – performance gain[通俗易懂]To achieve a better performance in Pro*C/C++ application, using host arrays would be efficient than

    2023-03-29
    123

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注