实验环境:两个MySQL实例

IP地址:10.0.0.201 端口:3306 (MySQL的Master)

IP地址:10.0.0.201 端口:3307 (MySQL的Slave)

需要的参数

  • server_id: 每个MySQL实例的server_id必须不一样。
  • log-bin:MySQL开启binglog日志。
  • gtid_mode=ON : MySQL开启GTID模式。
  • enforce-gtid-consistency=true :保证GTID的数据一致性。
  • log_slave_updates=1:Slave接收来自Master的更新操作日志,并记录至Slave的binlog日志中。可以完成级联复制
  • binlog_format= row:基于行格式,保证数据的一致。
  • skip-slave-start=1:保证Slave数据库启动的时候,slave不会自动启动(可以手动来启动 start slave)

步骤:

1.my.cnf的参数配置如下:

  • Master(3306)的配置
    server-id = 1203306
log-bin = /data/mysqldata/3306/binlog/mysql-bin #*********** GTID settting*******************
gtid_mode=ON
enforce-gtid-consistency=true
binlog_format= row
skip-slave-start=1
log_slave_updates = 1
  • Slave(3307)的配置
    server-id = 1203307
log-bin = /data/mysqldata/3307/binlog/mysql-bin #*********** GTID settting*******************
gtid_mode=ON
enforce-gtid-consistency=true
binlog_format= row
skip-slave-start=1
log_slave_updates = 1

2.为Replication创建一个用户

在master上,配置一个新用户,可以让slaves数据库能权限访问master数据库

mysql> CREATE USER 'repl'@'10.0.0.201' IDENTIFIED BY 'repl@3307';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'10.0.0.201';

3.保证Master数据库的数据一致性,设置为只读

mysql> SET @@global.read_only = ON;

3.备份Master数据库的数据

master导出备份
/usr/local/mysql/bin/mysqldump -uroot -p'zsd@7101' -S /data/mysqldata/3306/mysql.sock --all-databases --triggers --routines --events --flush-logs --single-transaction -e --default-character-set=utf8 | gzip > mysql_3306_full_backup_`date +%F`.sql.gz

参数详解:

  • all-databases: --all-databases, -A。备份所有数据库的所有表。。
  • triggers:备份所有触发器。
  • routines: 备份所有存储过程和函数。
  • events :数据库的事件。
  • flush-logs:在数据dump之前,刷新数据库的日志。
  • single-transaction:服务器dump之前,发起一个BEGIN SQL的语句, START TRANSACTION 放进一个事务里面,保证数据的一致性,防止锁表。
  • default-character-set=utf8:保证导出的字符集为UTF8
  • extended-insert:-e 产生一个相对来说较小的dump文件,加速导入数据库时,插入数据的速度。加快数据库的恢复。
slave导入备份
/usr/local/mysql/bin/mysql -uroot -p'zsd@3307' -S /data/mysqldata/3307/mysql.sock --default-character-set=utf8 < mysql_3306_full_backup_2018-06-01.sql

5.SLAVE追日志,完成复制操作

  • 抽象语句
mysql> CHANGE MASTER TO
> MASTER_HOST = host,
> MASTER_PORT = port,
> MASTER_USER = user,
> MASTER_PASSWORD = password,
> MASTER_AUTO_POSITION = 1;
  • 实战语句
CHANGE MASTER TO MASTER_HOST = '10.0.0.201',MASTER_PORT = 3306,MASTER_USER = 'repl',MASTER_PASSWORD = 'repl@3307',MASTER_AUTO_POSITION = 1;

6.启动Slave

mysql> START SLAVE;

7.查看slave状态

(root@localhost) [(none)]> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 10.0.0.201
Master_User: repl
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000011
Read_Master_Log_Pos: 1658
Relay_Log_File: relay-bin.000002
Relay_Log_Pos: 1832
Relay_Master_Log_File: mysql-bin.000011
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 1658
Relay_Log_Space: 2034
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id: 1203306
Master_UUID: 4160e9b3-58d9-11e8-b174-005056af6f24
Master_Info_File: mysql.slave_master_info
SQL_Delay: 0
SQL_Remaining_Delay: NULL
Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
Master_Retry_Count: 86400
Master_Bind:
Last_IO_Error_Timestamp:
Last_SQL_Error_Timestamp:
Master_SSL_Crl:
Master_SSL_Crlpath:
Retrieved_Gtid_Set: 4160e9b3-58d9-11e8-b174-005056af6f24:27-32
Executed_Gtid_Set: 4160e9b3-58d9-11e8-b174-005056af6f24:1-32,
e60a3353-6567-11e8-b305-005056af6f24:1-2
Auto_Position: 1
Replicate_Rewrite_DB:
Channel_Name:
Master_TLS_Version:
Master_public_key_path:
Get_master_public_key: 0
1 row in set (0.00 sec)

8.Master数据库,关闭只读

mysql> SET @@global.read_only = OFF;

知识点:完全删除replication的拓扑结构

(root@localhost) [(none)]> stop slave;

(root@localhost) [(none)]> RESET SLAVE ALL;

牛刀小试MySQL--基于GTID的replication的更多相关文章

  1. Mysql基于GTID复制模式-运维小结 (完整篇)

    先来看mysql5.6主从同步操作时遇到的一个报错:mysql> change master to master_host='192.168.10.59',master_user='repli' ...

  2. MySQL 基于 GTID 主从架构添加新 Slave 的过程

    内容全部来自: How to create/restore a slave using GTID replication in MySQL 5.6 需求说明 需求: 对于已经存在的 MySQL 主从架 ...

  3. Mysql基于GTID主从复制

    Mysql5.6基于GTID全局事务的复制 什么是GTID?   GTID(Global Transaction Identifiers)是全局事务标识 当使用GTIDS时,在主上提交的每一个事务都会 ...

  4. MYSQL 基于GTID的复制

    1.概述 从MYSQL5.6 开始,mysql开始支持GTID复制. 基于日志点复制的缺点: 从那个二进制日志的偏移量进行增量同步,如果指定错误会造成遗漏或者重复,导致数据不一致. 基于GTID复制: ...

  5. Mysql 基于GTID的主从复制(实操)

    实现环境: Master 主:192.168.0.102 (Mysql 5.6.36) Slave  从 :192.168.0.103 (Mysql 5.6.36) 步骤1.在主DB服务器上建立复制账 ...

  6. MySQL基于GTID的组复制(MGR)

    环境准备 IP 主机名 操作系统 192.168.131.129 mgr-node1 CentOS7.6 192.168.131.130 mgr-node2 CentOS7.6 192.168.131 ...

  7. 深入MySQL复制(二):基于GTID复制

    相比传统的MySQL复制,gtid复制无论是配置还是维护都要轻松的多.本文对gtid复制稍作介绍. MySQL基于GTID复制官方手册:https://dev.mysql.com/doc/refman ...

  8. percona mysql server5.7基于gtid的主从复制

    配置mysql基于gtid主从复制架构 一.二进制安装mysql [root@node5 data]# --Linux.x86_64.ssl101.tar.gz [root@node5 data]# ...

  9. 配置percona mysql server 5.7基于gtid主主复制架构

    配置mysql基于gtid主主复制架构 环境: 操作系统 centos7. x86_64 mysql版本:Percona-Server-- 测试环境: node1 10.11.0.210 node2 ...

随机推荐

  1. Alpha项目冲刺

    一.团队成员 学号 姓名 211606361 何承华(队长) 211606356 陈宇 211606360 丁培辉 211606333 温志铭 211606343 杨宇潇 211606391 张主强 ...

  2. mac virtualbox 安装

    在Mac上装virtualbox提示安装失败!!! 安全性与隐私的通用下点击允许!!!

  3. python学习第五章

    1.继承 即是一个派生的类(derived class)继承基类(base class)的字段和方法,继承也允许把一个 派生类的对象作为 一个基类 对象对待.通俗来讲就是方便,继承前人的代码,减少工作 ...

  4. RxSwift学习笔记8:filter/distinctUntilChanged/single/elementAt/ignoreElements/take/takeLast/skip/sample/debounce

    //filter:该操作符就是用来过滤掉某些不符合要求的事件. Observable.of(1,2,3,4,5,8).filter({ $0 % 2 == 0 }).subscribe { (even ...

  5. fork()函数、进程表示符、进程位置

    linux.centos6.5 fork()函数:作用于创建子进程.返回值有两个,一个是向父进程返回它的pid,一个是返回0: eg1: #include<stdio.h> #includ ...

  6. unidbgrid 设置 单元格颜色

    unidbgrid 设置 单元格颜色 2018年10月24日 11:32:41 ozhy111 阅读数:68   procedure TF_Resource2.UniDBGrid1DrawColumn ...

  7. 如何在html与delphi间交互代码

    [转]如何在html与delphi间交互代码 (2015-11-19 22:16:24) 转载▼ 标签: it 分类: uniGUI uniGUI总群中台中cmj朋友为我们总结了如下内容,对于利用de ...

  8. 还原Azure DevOps Server (TFS)中误删除的生成流水线

    流水线历史记录 DevOps Server流水线的历史记录有完善的版本日志,用户可以随时回退到修改过程中的任何一个版本,还能比较差异.这个历史记录功能可以和代码库中的版本控制媲美. 图一:生成历史记录 ...

  9. WPF简单的分页控件实现

    XAML代码(使用ItemsControl控件实现): <UserControl x:Class="SunCreate.Vipf.Client.UI.CityDoor.PageCont ...

  10. Java基础--枚举

    1.枚举简介 枚举是由一组固定的常量组成的类型,自定义数据类型. 枚举的常量值一定是可列举的有限值.常量值的类型都是public static final. 下面代码中的Gender 是一种自定义的数 ...