MySQL复制

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 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;
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
SQL 存储 关系型数据库
MySQL主从复制之原理&一主一从部署流程—2023.04
MySQL主从复制之原理&一主一从部署流程—2023.04
218 0
|
4月前
|
SQL 容灾 关系型数据库
MySQL 主从复制原理
MySQL 主从复制原理
43 1
MySQL 主从复制原理
|
6月前
|
SQL 关系型数据库 MySQL
MySql主从复制原理及其搭建
MySql主从复制原理及其搭建
|
8月前
|
SQL 负载均衡 关系型数据库
MySQL主从复制的原理与实操+mycat2读写分离
MySQL主从复制的原理与实操+mycat2读写分离
136 0
|
12月前
|
SQL 缓存 算法
【MySQL】主从复制(重点:主从复制原理)
本文重点介绍MySQL的主从复制概述,作用,原理,同步数据一致性问题。
116 0
|
SQL 关系型数据库 MySQL
面试官问:了解Mysql主从复制原理么?我呵呵一笑
搭建Mysql主从同步之前,我们先来说他们之间同步的过程与原理: 同步复制过程 献上一张图,这张图诠释了整个同步过程
|
SQL 关系型数据库 MySQL
MySQL的Binlog日志和Relay Log日志都可以用来主从复制,区别是什么?底层原理是什么?
MySQL的Binlog日志和Relay Log日志都可以用来主从复制,区别是什么?底层原理是什么?
670 0
|
SQL 关系型数据库 MySQL
什么是MySQL的复制表?
什么是MySQL的复制表?
|
SQL 关系型数据库 MySQL
什么是MySQL的复制表?
如果我们需要完全的复制MySQL的数据表,包括表的结构,索引,默认值等。 如果仅仅使用CREATE TABLE ... SELECT命令,是无法实现的。
什么是MySQL的复制表?