牛刀小试MySQL--基于GTID的replication
实验环境:两个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的更多相关文章
- Mysql基于GTID复制模式-运维小结 (完整篇)
		先来看mysql5.6主从同步操作时遇到的一个报错:mysql> change master to master_host='192.168.10.59',master_user='repli' ... 
- MySQL 基于 GTID 主从架构添加新 Slave 的过程
		内容全部来自: How to create/restore a slave using GTID replication in MySQL 5.6 需求说明 需求: 对于已经存在的 MySQL 主从架 ... 
- Mysql基于GTID主从复制
		Mysql5.6基于GTID全局事务的复制 什么是GTID? GTID(Global Transaction Identifiers)是全局事务标识 当使用GTIDS时,在主上提交的每一个事务都会 ... 
- MYSQL 基于GTID的复制
		1.概述 从MYSQL5.6 开始,mysql开始支持GTID复制. 基于日志点复制的缺点: 从那个二进制日志的偏移量进行增量同步,如果指定错误会造成遗漏或者重复,导致数据不一致. 基于GTID复制: ... 
- Mysql 基于GTID的主从复制(实操)
		实现环境: Master 主:192.168.0.102 (Mysql 5.6.36) Slave 从 :192.168.0.103 (Mysql 5.6.36) 步骤1.在主DB服务器上建立复制账 ... 
- MySQL基于GTID的组复制(MGR)
		环境准备 IP 主机名 操作系统 192.168.131.129 mgr-node1 CentOS7.6 192.168.131.130 mgr-node2 CentOS7.6 192.168.131 ... 
- 深入MySQL复制(二):基于GTID复制
		相比传统的MySQL复制,gtid复制无论是配置还是维护都要轻松的多.本文对gtid复制稍作介绍. MySQL基于GTID复制官方手册:https://dev.mysql.com/doc/refman ... 
- percona mysql server5.7基于gtid的主从复制
		配置mysql基于gtid主从复制架构 一.二进制安装mysql [root@node5 data]# --Linux.x86_64.ssl101.tar.gz [root@node5 data]# ... 
- 配置percona mysql server 5.7基于gtid主主复制架构
		配置mysql基于gtid主主复制架构 环境: 操作系统 centos7. x86_64 mysql版本:Percona-Server-- 测试环境: node1 10.11.0.210 node2 ... 
随机推荐
- 关于loadtxt编码问题的解决方法
			I am trying to load data with numpy.loadtxt... The file im trying to read is using cp1252 coding. Is ... 
- django 的一些了解
			1.实现列表分页显示 https://mozillazg.com/2013/01/django-pagination-by-use-paginator.html 
- C++ MFC棋牌类小游戏day6
			双人单机小游戏做完了,规则那部分还没介绍,暂时不打算介绍了,因为写的这个bug太多,我打算重新修改. 链接:https://pan.baidu.com/s/1XQKPSv0Tw36Qi2TeaRJiM ... 
- fortran77读写文本文档
			PROGRAM WRITETEXT IMPLICIT NONE INTEGER,PARAMETER :: NE=!fortran90 语法定义变量 DOUBLE PRECISION A(,),B(,) ... 
- 让IE8支持html5中的video标签
			这是一篇综合几个前辈的解决方案. 使用video的时候,要遇到的问题. ①不兼容ie9及其以下版本 在<head>里添加两行, 参考张鑫旭前辈的博客,但是在ie8中薄播放. <!-- ... 
- UML标准建模语言与应用实例
			一.基本信息 标题:UML标准建模语言与应用实例 时间:2012 出版源:科技创新导报 领域分类:UML标准建模语言 面向对象 系统分析与设计 二.研究背景 问题定义:UML建模语言用图形来表现典型的 ... 
- JS中多维数组的深拷贝的多种实现方式
			因为javascript分原始类型与引用类型(与java.c#类似).Array是引用类型,所以直接用=号赋值的话,只是把源数组的地址(或叫指针)赋值给目的数组,并没有实现数组的数据的拷贝.另外对一维 ... 
- 背水一战 Windows 10 (78) - 自定义控件: 基础知识, 依赖属性, 附加属性
			[源码下载] 背水一战 Windows 10 (78) - 自定义控件: 基础知识, 依赖属性, 附加属性 作者:webabcd 介绍背水一战 Windows 10 之 控件(自定义控件) 自定义控件 ... 
- Alpha代码规范、冲刺任务与计划
			Alpha代码规范.冲刺任务与计划 团队名称: 云打印 作业要求: Alpha代码规范.冲刺任务与计划 作业目标:代码规范.冲刺任务与计划. 团队队员 队员学号 队员姓名 个人博客地址 备注 2216 ... 
- Ubuntu18.04安装网易云音乐
			一. 安装 去网易云官网下载对应于ubuntu系统的安装包 安装依赖 dpkg -s libcanberra-gtk-module #检查依赖是否安装 sudo apt install libcanb ... 
