MySQL复制

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: MySQL复制MySQL传统的主从复制master节点的配置server_id=1sync_binlog=1log_bin=master-binmysql> create user 'repl'@'192.

MySQL复制

MySQL传统的主从复制

master节点的配置

  • server_id=1
  • sync_binlog=1
  • log_bin=master-bin
  • mysql> create user 'repl'@'192.168.1.%' identified by 'password';
  • mysql> grant replication slave on . to 'repl'@'192.168.1.%';

slave节点的配置

  • server_id=2
  • relay_log=slave-bin
  • skip-slave-start=on # 默认MySQL启动就会自动start slave, 设置为on则需要手动start slave(推荐)
  • read_only=on # slave节点应该是只读的, 对super用户和relay log的repaly无效
  • mysql> change master to ...
  • mysql> start slave # 并不是连接到master节点, 而是设置连接到master节点的参数, 生成配置文件master.info在datadir项指定的目录中
  • mysql> stop slave

查看slave节点的状态

  • show slave status\G;

查看master节点的状态

  • show master status\G:

将master节点的数据备份恢复到slave节点上

  • mysqldump -uroot -proot -q -c --lock-all-tables --master-data=2 --no-autocommit --flush-logs --databases mydb > backup.sql
  • scp backup.sql root@node2:~
  • mysql -uroot -proot < backup.sql

MySQL传统的主从复制之辅助master

主要对充当master节点的slave节点进行配置

  • log_slave_updates=on # 默认情况下在replay中继日志时不会记录到binlog中, 开启该选项才可以
  • log_bin=on # 要记录二进制日志这个是必须的, log_slave_updates和log_bin是要同时设置的
  • 一个slave2是以slave为master的slave节点, 因为都是slave节点, 所以可以将他们都停下来进行快速的冷备份
    • 将slave中的数据文件拷贝到slave2中
    • 在slave2节点中, 删除拷贝过来的文件中的master.info, relay_log,info, 所有的二进制日志
  • 为slave节点添加具有复制权限的日志
    • create user 'repl'@'192.168.1.%' identified by 'password';
    • grant replication slave on . to 'repl'@'192.168.1.%';
  • 在slave2节点中配置连接slave的参数
    • mysql> change master to...
    • read_only=on
    • skip_slave_start=on

在master节点查看已经使用start slave连接的slave节点

  • show slave hosts;

slave转为master

  • 该slave必须是一个开启了log_slave_updates和log_bin的辅助master节点
  • mysql> stop slave;
  • systemctl stop mariadb
  • 删除master.info, relay_log.info 和 中继日志
  • systemctl start mariadb
  • 剩余的slave节点的master都指向该转为master的slave节点即可

MySQL主从复制(基于GTID)

master节点

  • 配置文件中相对于传统复制添加 gtid_mode=on 和 enforce_gtid_consistency=on
  • 创建具有复制权限的用户
  • show master status; 获取当前的gtid

slave节点

  • 配置文件中相对于传统复制添加 gtid_mode=on 和 enfoce_gtid_consistency=on
  • reset master
  • show global variables like '%gtid%'; 找到 gtid_executed 和 gtid_purged, 这两个变量是与gtid有关的
  • set @@gobal.gtid_purged=从master节点得到的gtid号, 这样再第一次同步时就可以跳过重复和一些不必要的操作减少错误和提高效率

MySQL半复制

与传统复制唯一的不同就是需要在配置文件中添加关于加载插件的信息

在master节点

  • plugin-load='rpl_semi_sync_master=semisync_master.so'
  • rpl_semi_sync_master_enabled=1

在slave节点

  • plugin-load='rpl_semi_sync_slave=semisync_slave.so'
  • rpl_semi_sync_slave_enabled=1

辅助master节点

  • plugin-load='rpl_semi_sync_master=semisync_master.so;rpl_semi_sync_slave=semisync_slave.so'
  • rpl_semi_sync_slave_enabled=1
  • rpl_semi_sync_master_enabled=1

查看相关信息

  • show plugins;
  • show status like '%semi%';
  • show global variables like '%semi%';

在mysql shell中加载插件和启动插件而不是通过编写配置文件

  • help install;
    • master节点
      • install plugin rpl_semi_sync_master soname 'semisync_master.so';
      • set @@global.rpl_semi_sync_master_enabled=0;
    • slave节点
      • install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
      • set @@global.rpl_semi_sync_slave_enabled=0;
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
5月前
|
SQL 关系型数据库 MySQL
面试官:说一下MySQL主从复制的原理?
面试官:说一下MySQL主从复制的原理?
161 0
面试官:说一下MySQL主从复制的原理?
|
12月前
|
SQL 存储 关系型数据库
MySQL主从复制之原理&一主一从部署流程—2023.04
MySQL主从复制之原理&一主一从部署流程—2023.04
375 0
|
5月前
|
SQL 关系型数据库 MySQL
MySQL中主从复制的原理和配置命令
要原因包括提高性能、实现高可用性、数据备份和灾难恢复。了解两大线程( I/O 和 SQL)I/O线程:目的:I/O线程主要负责与MySQL服务器之外的其他MySQL服务器进行通信,以便复制(replication)数据。 功能: 当一个MySQL服务器作为主服务器(master)时,I/O线程会将变更日志(binary log)中的事件传输给从服务器(slave)。从服务器上的I/O线程负责接收主服务器的二进制日志,并将这些事件写入本地的中继日志(relay log)。 配置: 在MySQL配置文件中,你可以通过配置参数如和来启用二进制日志和指定服务器ID。log-bin server
129 1
MySQL中主从复制的原理和配置命令
|
2月前
|
SQL 关系型数据库 MySQL
说一下MySQL主从复制的原理?
【8月更文挑战第24天】说一下MySQL主从复制的原理?
52 0
|
2月前
|
SQL canal 关系型数据库
(二十四)全解MySQL之主从篇:死磕主从复制中数据同步原理与优化
兜兜转转,经过《全解MySQL专栏》前面二十多篇的内容讲解后,基本对MySQL单机模式下的各方面进阶知识做了详细阐述,同时在前面的《分库分表概念篇》、《分库分表隐患篇》两章中也首次提到了数据库的一些高可用方案,但前两章大多属于方法论,并未涵盖真正的实操过程。接下来的内容,会以目前这章作为分割点,开启MySQL高可用方案的落地实践分享的新章程!
857 1
|
5月前
|
关系型数据库 MySQL Linux
【mysql】MySql主从复制,从原理到实践!
【mysql】MySql主从复制,从原理到实践!
122 0
|
5月前
|
SQL 容灾 关系型数据库
MySQL 主从复制原理
MySQL 主从复制原理
71 1
MySQL 主从复制原理
|
12月前
|
SQL 关系型数据库 MySQL
MySql主从复制原理及其搭建
MySql主从复制原理及其搭建
|
SQL 弹性计算 负载均衡
MySQL主从复制原理和配置实现
MySQL主从复制原理和配置实现
104 0
MySQL主从复制原理和配置实现
|
SQL 负载均衡 关系型数据库
MySQL主从复制的原理与实操+mycat2读写分离
MySQL主从复制的原理与实操+mycat2读写分离
230 0