MySQL 的异步复制(mysql 异步写入)

yumo66610个月前 (05-09)技术文章144

MySQL 复制属于水平扩展架构,是构建大规模高性能应用的基础。在 MySQL 中,有两种常用的搭建复制的方式:异步复制和增强半同步复制,本小节主要介绍 MySQL 的异步复制。

1. 复制概述

复制解决的问题,是让一台数据库的数据与其他数据库保持同步。复制的原理是将主库的 DML 和 DDL操作通过 binlog 日志传到从库,然后在从库上重放这些日志,从而使主库和从库保持数据同步。

MySQL复制的优点:

  • 实现高可用架构,避免单点故障;
  • 可以在从库执行查询,分担主库的查询压力;
  • 可以在从库执行备份,降低主库受到的影响。

2. 异步复制

MySQL 的复制默认是异步复制,主从异步复制是 MySQL 很常见的复制场景,搭建步骤也相对简单。下面从实战的角度一步步搭建异步复制环境。

2.1 基本环境


Master

Slave

MySQL版本

MySQL-5.7.31-x86_64

MySQL-5.7.31-x86_64

IP

192.168.0.1

192.168.0.2

port

3306

3306

2.2 主库配置

修改 my.cnf 文件:

gtid-mode = on
enforce-gtid-consistency = 1

binlog_format = row
server-id = 330601
log-bin = /mysql/log/mysql-bin
binlog_cache_size = 1M

创建复制用账号:

create user 'repl'@'192.168.0.2' identified by '123456';
grant replication slave on *.* to 'repl'@'192.168.0.2';

2.3 从库配置

修改 my.cnf 文件:

gtid-mode = on
enforce-gtid-consistency = 1

binlog_format = row
server-id = 330602
log-bin = /mysql/log/mysql-bin
binlog_cache_size = 1M
skip_slave_start = 1

导出导入:

--主库导出
mysqldump -uroot -p --single-transaction --master-data=2 --databases test123 > test_200908.sql

--从库导入
mysql -uroot -p < test_200908.sql

--调整复制起点
change master to master_host='192.168.0.1', master_port=3306, master_user='repl', master_password='123456', master_auto_position=1;

--开始复制
start slave;

--查看复制
show slave status\G;

2.4 环境校验

--主库,创建表t1并插入数据
use test123;
create table t1(id int);
insert into t1 values(1);
select * from t1;

--从库,检查t1表是否存在
use test123;
select * from t1;

2.5 扩展问题

如果主库导出时出现如下警告信息:

mysqldump -uroot -p --single-transaction --master-data=2 --databases test123 > test_200908.sql
Enter password: 

Warning: A partial dump from a server that has GTIDs will by default include the GTIDs of all transactions, even those that changed suppressed parts of the database. If you don't want to restore GTIDs, pass --set-gtid-purged=OFF. To make a complete dump, pass --all-databases --triggers --routines --events.

当MySQL为GTID模式时,用mysqldump导出默认会带上当前已执行的GTID

  1. 如果是从库的GTID_EXECUTED为空值,即从库无任何事务操作,则无需理会;
  2. 如果是从库的GTID_EXECUTED为非空,两种解决方案。
    在主库 mysqldump 导出时,加上参数 --set-gtid-purged=OFF,适合场景为导出部分数据;
    在从库 mysqldump 导入前,执行 reset master,适合场景为搭建新从库。

3. 小结

本小节主要介绍了 MySQL 复制的基本概念和 MySQL 异步复制的搭建方式。

异步复制的配置步骤相对简单:

  • 一般来说,需确保主从库安装相同版本的数据库
  • 在主库需新建一个复制账号,并授予replication slave权限

相关文章

这份MySQL全面手册,受喜爱程度不输任何大厂笔记

MySQL是目前最流行的开放源代码数据库管理系统,全世界的装机量已超过400万台。本书详细介绍了如何使用可定制的关系数据库管理系统支持健壮的、可靠的、任务关键的应用程序。今天给大家分享的是一份MySQ...

全程软件测试(六十八):数据库MySQL从零开始入门—读书笔记

第一章 数据库概述1.1、数据库的好处将数据持久化到本地提供结构化查询功能1.2、数据库的常见概念DB:数据库,存储数据的仓库DBMS:数据库管理系统,又称为数据库软件或者数据库产品,用于创建和管理数...

深夜整理!55道BAT高频MySQL灵魂拷问,背完跳槽涨薪不再是梦想!

"最近在帮团队面试MySQL方向的候选人,发现一个奇怪现象:80%的求职者能写基本的CRUD,但被问到『mysql_fetch_array 和 mysql_fetch_object 的区别是什...

MySQL、Oracle、SqlServer的区别(oraclemysqlsqlserver三者的区别)

鉴于和数据库打交道日益频繁,遂决定写一篇关于Oracle、SqlServer、MySQL区别的个人观点。MySQL是大学时的主要学习对象,但刚参加工作时转到了SqlServer,现在主要接触的是Ora...

学Access好还是MySQL好?(数据库access好还是mysql好)

都学呗,成年人要多做加法题,少做选择题。把Access和MySQL这俩软件都下载下来,亲自上手搞一搞,对照着学习资料做一做,哪个对业余选手更实用,基本是一目了然的事情~Access数据库是微软Offi...

阿里面试:MySQL Binlog有哪些格式?底层原理?优缺点?

binlog的格式也有三种:STATEMENT、ROW、MIXED ,下面我详解binlog三种模式@mikechenStatement模式Statement模式:是基于SQL语句的复制(statem...