MySQL入门学习-运维与架构.多源复制

MySQL的多源复制是一个高级特性,它允许一个MySQL服务器(从库)从多个源服务器(主库)复制数据。这种功能在多种场景下都非常有用,比如数据合并、分布式数据库架构中的数据同步等。

一、多源复制的特点和使用方法:

1. 特点:

  • 一个从库可以同时从多个主库复制数据。

  • 多个主库之间没有主从关系。

  • 主要用于将多个MySQL中的数据聚合到一个MySQL中。

2. 使用方法:

  • 在从库上设置 'master-info-repository' 和 'relay-log-info-repository' 参数,以确保数据一致性。

  • 需要确保从每个主数据库中复制不同的数据库,或者处理复制数据时产生的数据冲突。

  • 配置过程中涉及到修改MySQL的配置文件 'my.cnf',设置相关的复制参数。

3. 配置步骤(简化版):

  • 修改每台MySQL服务器的 'my.cnf' 文件,添加必要的复制参数。

  • 在主库上执行锁表操作,并查看主库的运行状态。

  • 在从库上创建数据同步的账户信息,并配置从库的设置。

  • 在从库上启动MySQL从库服务,并查看从库的运行状态。

二、与其他复制的比较:

  • 与传统的单源复制相比,多源复制可以更有效地利用从库资源,因为它可以同时处理来自多个主库的数据。

  • 与 'multi-master' 复制不同,'multi-source' 复制是将多个主库同步到一个从库上面,而 'multi-master' 通常是指环形复制,数据可以在任意主机间复制。

三、高级应用:

- 数据分析:

可以将各个业务部门的数据复制到统一的数据库中,便于数据分析部门使用。

- 数据汇总:

在从服务器上进行数据汇总,尤其适用于主服务器进行了分库分表操作的场景。

- 数据备份:

可以将多个主服务器的数据同步到一个从服务器进行备份,减少资源浪费和维护成本。

四、示例代码:

以下是在从库上设置复制的示例代码:

sql 复制代码
-- 在从库上创建同步账户
CREATE USER 'sync_user'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'sync_user'@'%';
-- 在从库上配置主库信息
CHANGE MASTER TO MASTER_HOST='master1_host', MASTER_USER='sync_user', MASTER_PASSWORD='password', ...;
-- 启动从库服务
START SLAVE;
相关推荐
星霜笔记3 小时前
Docker 部署 MariaDB+phpMyAdmin+Nextcloud 完整教程
运维·数据库·docker·容器·mariadb
_Kayo_6 小时前
node.js 学习笔记3 HTTP
笔记·学习
poemyang8 小时前
十年大厂员工终明白:MySQL性能优化的尽头,是对B+树的极致理解
mysql·pagecache·顺序i/o·局部性原理·b tree·b+ tree
wyiyiyi9 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
CCCC13101639 小时前
嵌入式学习(day 28)线程
jvm·学习
天宇_任9 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
星星火柴93610 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
小狗爱吃黄桃罐头10 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
艾莉丝努力练剑11 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
武昌库里写JAVA12 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习