MySQL的复制:https://www.cnblogs.com/wxzhe/p/10051114.html

级联复制的结构如图

我们来设置基于filename和pos的级联复制,并且接受mysql-utilities工具中mysqlreplicate的用法!

首先在MySQL官网下载mysql-utilities工具

  1. [root@test2 src]# tar zxvf mysql-utilities-1.6.5.tar.gz
  2. [root@test2 src]# cd mysql-utilities-1.6.5
  3. [root@test2 mysql-utilities-1.6.5]# python setup.py install
  4.  
  5. #工具已经安装完毕
    [root@test3 ~]# mysqlreplicate --version
    MySQL Utilities mysqlreplicate version 1.6.5
    License type: GPLv

master:10.0.102.214          test3

slave  :10.0.102.204           test2

slave-2: 10.0.102.179          test1

第一步:首先要保证要备份的主从服务器数据的一致,先搭建主从(master---slave)

  1. [root@test3 ~]# mysqldump -uroot -p123456 --single-transaction --all-databases > all.sql #这里的提示,因为是测试环境因此没有加--set-gtid-purged=OFF参数
  2. mysqldump: [Warning] Using a password on the command line interface can be insecure.
  3. 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 do not want to restore GTIDs, pass --set-gtid-purged=OFF. To make a complete dump, pass --all-databases --triggers --routines --events.
  4.  
  5. [root@test2 ~]# mysql -uroot -p123456 < all.sql #在从库上导入数据,这里报错了
  6. mysql: [Warning] Using a password on the command line interface can be insecure.
  7. ERROR 1840 (HY000) at line 24: @@GLOBAL.GTID_PURGED can only be set when @@GLOBAL.GTID_EXECUTED is empty.
  8. [root@test2 ~]# mysql -uroot -p123456 #解决办法
  9. mysql: [Warning] Using a password on the command line interface can be insecure.
  10. Welcome to the MySQL monitor. Commands end with ; or \g.
  11. Your MySQL connection id is 5
  12. Server version: 5.7.22-log MySQL Community Server (GPL)
  13.  
  14. Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
  15.  
  16. Oracle is a registered trademark of Oracle Corporation and/or its
  17. affiliates. Other names may be trademarks of their respective
  18. owners.
  19.  
  20. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
  21. mysql> select @@GLOBAL.GTID_EXECUTED;
  22. +------------------------------------------+
  23. | @@GLOBAL.GTID_EXECUTED |
  24. +------------------------------------------+
  25. | fc5f303f-f6c1-11e8-98bc-fa1dae125200:1-3 |
  26. +------------------------------------------+
  27. 1 row in set (0.00 sec)
  28.  
  29. mysql> reset master;
  30. Query OK, 0 rows affected (0.01 sec)
  31.  
  32. mysql> select @@GLOBAL.GTID_EXECUTED;
  33. +------------------------+
  34. | @@GLOBAL.GTID_EXECUTED |
  35. +------------------------+
  36. | |
  37. +------------------------+
  38. 1 row in set (0.00 sec)
  39.  
  40. mysql> exit
  41. Bye
  42. [root@test2 ~]# mysql -uroot -p123456 < all.sql

数据已经保持一致:

在主上查看filename和pos:

  1. mysql> show master status;
  2. +------------------+----------+--------------+------------------+-------------------+
  3. | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
  4. +------------------+----------+--------------+------------------+-------------------+
  5. | test3-bin.000001 | 154 | | | |
  6. +------------------+----------+--------------+------------------+-------------------+
  7. 1 row in set (0.00 sec)

在从或主服务器上执行如下命令:【需要注意的是这个--rpl-user指定的用户名和密码需要在master上创建】

  1. [root@test2 ~]# mysqlreplicate --master=root:@10.0.102.214 --slave=root:@10.0.102.204 --rpl-user=repl: --master-log-file=test3-bin. --master-log-pos= -vv
  2. WARNING: Using a password on the command line interface can be insecure.
  3. # master on 10.0.102.214: ... connected.
  4. # slave on 10.0.102.204: ... connected.
  5. # master id =
  6. # slave id =
  7. # master uuid = 4687e05d-f37f-11e8-8fc7-fa336351fc00
  8. # slave uuid = f1983579-f6c4-11e8--fa1dae125200
  9. # Checking InnoDB statistics for type and version conflicts.
  10. # Checking storage engines...
  11. # Checking for binary logging on master...
  12. # Setting up replication...
  13. # Connecting slave to master...
  14. # CHANGE MASTER TO MASTER_HOST = '10.0.102.214', MASTER_USER = 'repl', MASTER_PASSWORD = '', MASTER_PORT = , MASTER_AUTO_POSITION=
  15. # Starting slave from master log file 'test3-bin.000001' using position ...
  16. # IO status: Waiting for master to send event
  17. # IO thread running: Yes
  18. # IO error: None
  19. # SQL thread running: Yes
  20. # SQL error: None
  21. # ...done.

mysqlreplicate命令的用法如下:

  1. [root@test2 log]# mysqlreplicate --help
  2. MySQL Utilities mysqlreplicate version 1.6.
  3. License type: GPLv2
  4. Usage: mysqlreplicate --master=root@localhost: --slave=root@localhost: --rpl-user=rpl:passwd
  5.  
  6. mysqlreplicate - establish replication with a master
  7.  
  8. Options:
  9. --version show program's version number and exit
  10. --help display a help message and exit
  11. --license display program's license and exit
  12. --master=MASTER connection information for master server in the form:
  13. <user>[:<password>]@<host>[:<port>][:<socket>] or
  14. <login-path>[:<port>][:<socket>] or <config-
  15. path>[<[group]>].
  16. --slave=SLAVE connection information for slave server in the form:
  17. <user>[:<password>]@<host>[:<port>][:<socket>] or
  18. <login-path>[:<port>][:<socket>] or <config-
  19. path>[<[group]>].
  20. --rpl-user=RPL_USER the user and password for the replication user
  21. requirement, in the form: <user>[:<password>] or
  22. <login-path>. E.g. rpl:passwd
  23. -p, --pedantic fail if storage engines differ among master and slave.
  24. --test-db=TEST_DB database name to use in testing replication setup
  25. (optional)
  26. --master-log-file=MASTER_LOG_FILE
  27. use this master log file to initiate the slave.
  28. --master-log-pos=MASTER_LOG_POS
  29. use this position in the master log file to initiate
  30. the slave.
  31. -b, --start-from-beginning
  32. start replication from the first event recorded in the
  33. binary logging of the master. Not valid with --master-
  34. log-file or --master-log-pos.
  35. -v, --verbose control how much information is displayed. e.g., -v =
  36. verbose, -vv = more verbose, -vvv = debug
  37. -q, --quiet turn off all messages for quiet execution.
  38.  
  39. #这个--rpl-user指定的用户名和密码,不能识别在master上创建的使用“%”的标识,也就是master需要指定创建"repl"@"10.0.102.204"的用户名,
    "repl"@"%"好像就不可以。

从服务器上一定要开启二进制日志和log_slave_updates参数。因为若是不设置log_slave_updates,从服务器只是开启了二进制日志,但是却没有向二进制日志里面写入数据。

测试如下:从没有开启log_slave_updates!

  1. #从服务器二进制日志行数
  2. [root@test2 mysql]# mysqlbinlog test2-bin. | wc -l
  3.  
  4. #主上插入数据
  5. mysql> insert into tb2 select null;
  6. Query OK, row affected (0.02 sec)
  7. Records: Duplicates: Warnings:
  8.  
  9. mysql> insert into tb2 select null;
  10. Query OK, row affected (0.00 sec)
  11. Records: Duplicates: Warnings:
  12.  
  13. mysql> insert into tb2 select null;
  14. Query OK, row affected (0.00 sec)
  15. Records: Duplicates: Warnings:
  16.  
  17. mysql> insert into tb2 select null;
  18. Query OK, row affected (0.00 sec)
  19. Records: Duplicates: Warnings:
  20.  
  21. mysql> insert into tb2 select null;
  22. Query OK, row affected (0.01 sec)
  23. Records: Duplicates: Warnings:
  24.  
  25. mysql> insert into tb2 select null;
  26. Query OK, row affected (0.01 sec)
  27. Records: Duplicates: Warnings:
  28.  
  29. mysql> insert into tb2 select null;
  30. Query OK, row affected (0.01 sec)
  31. Records: Duplicates: Warnings:
  32.  
  33. #从服务器数据同步过来
  34. mysql> select * from tb2;
  35. +----+
  36. | id |
  37. +----+
  38. | |
  39. | |
  40. | |
  41. | |
  42. | |
  43. | |
  44. | |
  45. +----+
  46. rows in set (0.00 sec)
  47.  
  48. #但是二进制行数没有变,也就是二进制日志没有增加
  49. [root@test2 mysql]# mysqlbinlog test2-bin. | wc -l

log_slave_updates参数测试

slave服务器log_slave_updates,以当前的slave为主,做salve~slave-2的主从!

把当前slave的数据备份,在slave-2上恢复!

【过程略,参考上面的】

从服务器上的server-id要设置为唯一的!【在集群中是唯一的】

  1. mysqlreplicate --master=root:@10.0.102.204 --slave=root:@10.0.102.179 --rpl-user=repl: --master-log-file=test2-bin. --master-log-pos= -vv
  2.  
  3. #repl-user:指定的用户需要提前在对应的master上创建!

使用show slave status检查是否成功!

  1. mysql> desc test1;
  2. +-------+---------+------+-----+---------+-------+
  3. | Field | Type | Null | Key | Default | Extra |
  4. +-------+---------+------+-----+---------+-------+
  5. | a | int() | NO | PRI | NULL | |
  6. +-------+---------+------+-----+---------+-------+
  7. row in set (0.00 sec)
  8.  
  9. mysql> create table test2(host varchar());
  10. Query OK, rows affected (0.02 sec)
  11.  
  12. mysql> insert into test2 select @@hostname;
  13. Query OK, row affected (0.02 sec)
  14. Records: Duplicates: Warnings:
  15.  
  16. mysql> select * from test2;
  17. +-------+
  18. | host |
  19. +-------+
  20. | test3 |
  21. +-------+
  22. row in set (0.00 sec)
  23.  
  24. mysql>
  25.  
  26. slave上查看
  27. mysql> select @@hostname;
  28. +------------+
  29. | @@hostname |
  30. +------------+
  31. | test2 |
  32. +------------+
  33. row in set (0.00 sec)
  34.  
  35. mysql> select * from test2;
  36. +-------+
  37. | host |
  38. +-------+
  39. | test3 |
  40. +-------+
  41. row in set (0.00 sec)
  42.  
  43. slave-2上查看数据
  44. mysql> select @@hostname;
  45. +------------+
  46. | @@hostname |
  47. +------------+
  48. | test1 |
  49. +------------+
  50. row in set (0.00 sec)
  51.  
  52. mysql> select * from test2;
  53. +-------+
  54. | host |
  55. +-------+
  56. | test3 |
  57. +-------+
  58. row in set (0.00 sec)

级联复制测试

多源复制

一个slave连接多个master并接收所有来自master的变更,这种架构称为多源架构。

注意与多主架构的区分:在多源架构中,变更来自多个master;而在多主拓补架构中,将每个master上的变更复制到其他所有的master,整个服务器扮演单个master的角色。

若数据库的状态不一致,需要先备份,恢复数据使其达到一致的状态!

master1   ---test1------10.0.102.179

master2   ---test2------10.0.102.204

slave   ---test3------10.0.102.214

多源复制过程与传统异步复制过程是一样的!

创建复制账户,查看复制日志点位置!

  1. #在两个从上执行
  2. mysql> grant all privileges on *.* to "repl"@"%" identified by "";
  3. Query OK, rows affected, warning (0.01 sec)
  4. mysql> show master status; #查看日志点的位置

然后再从上开启复制:

  1. mysql> change master to master_host="10.0.102.204", master_user="root",master_password="",master_log_file="test2-bin.000003",master_log_pos= for channel "ch1";
  2. ERROR (HY000): To have multiple channels, repository cannot be of type FILE; Please check the repository configuration and convert them to TABLE.
  3. mysql>
  4.  
  5. #这里报错需要设置relay_log_info_repository 为table,把relay-log的信息写进表中!
    master_info_repository =  TABLE #建议设置为table
    relay_log_recovery = 1    #I/O thread crash safe
    relay_log_info_repository = TABLE  # SQL thread crash safe
    read_only = 1
    super_read_only = on   #mysql5.7 加入的
  6.  
  7. 设置之后重启服务器:
    语句的后面加上了for channel
    mysql> change master to master_host="10.0.102.204", master_user="root",master_password="123456",master_log_file="test2-bin.000003",master_log_pos=514 for channel "ch1";
    Query OK, 0 rows affected, 2 warnings (0.05 sec)
  8.  
  9. mysql> change master to master_host="10.0.102.204", master_user="root",master_password="123456",master_log_file="test2-bin.000001",master_log_pos=154 for channel "ch2";
    Query OK, 0 rows affected, 2 warnings (0.03 sec)
  10.  
  11. #分别启动
    mysql> start slave for channel "ch1";
    Query OK, 0 rows affected (0.04 sec)
  12.  
  13. mysql> start slave for channel "ch2";
    Query OK, 0 rows affected (0.00 sec)
    然后可以使用show slave status for channel 命令查看对应的状态!

mysql的级联复制和多源复制的更多相关文章

  1. MySQL 5.7.9的多源复制

    什么是多源复制? 首先,我们需要清楚 multi-master 与multi-source 复制不是一样的. Multi-Master 复制通常是环形复制,你可以在任意主机上将数据复制给其他主机. M ...

  2. MySQL灾备恢复在线主从复制变成主主复制及多源复制【转】

    生产主主复制(A<--->B),和灾备主从复制(B--->C).当生产出现问题时,数据写入切换到灾备数据库,待生产恢复后,将灾备回写到生产.步骤如下: 1.灾备与生产其中一台建立主主 ...

  3. mysql的GTID复制和多源复制

    配置基于GTID的复制--------------------------------------------在参数文件/etc/my.cnf增加下面内容:主库master_info_reposito ...

  4. MariaDB的GTID复制和多源复制

    什么是GTID? GTID就是全局事务ID(global transaction identifier ),最初由google实现,官方MySQL在5.6才加入该功能.GTID实际上是由UUID+TI ...

  5. mariadb-10GTID复制及多源复制

    ---本文大纲 一.什么是GTID 二.应用场景 三.多线程复制说明 四.实现过程 五.多源复制原理 六.实现过程 ---------------------------------- 一.什么是GI ...

  6. mysql架构解读~mysql的多源复制

    一 场景需求 多源复制版本 5.7,目标主机5.6.21 4个DB机器的某些数据库需要数据汇总进行连表查询 二 进行搭建  1 导出相应的目的库     mysqldump -uuser -ppass ...

  7. MySQL多源复制(八)

    一.什么是多源复制 MySQL 5.7发布后,在复制方面有了很大的改进和提升.比如开始支持多源复制(multi-source)以及真正的支持多线程复制了.多源复制可以使用基于二进制日志的复制或者基于事 ...

  8. MySQL复制(四)—多源(主)复制

    (一)多主复制概述 MySQL从5.7版本开启支持多主复制,所谓多主复制,是将多个主库的数据复制到一个从库中.通常用于数据仓库整合数据,比如OLTP系统为了分散业务压力,对数据库进行分库分表,当要对数 ...

  9. 基于Docker搭建MySQL多源复制环境

    MySQL5.7在主从复制上面相对之前版本多了一些新特性,包括多源复制.基于组提交的并行复制.在线修改Replication Filter.GTID增强.半同步复制增强等. 多源复制:多源复制加入了一 ...

随机推荐

  1. [实战]MVC5+EF6+MySql企业网盘实战(1)

    写在前面 不久前,一个朋友让帮他弄一个单位的企业网盘的管理站点,一直忙,最近抽出了点时间,也想琢磨琢磨mvc,ef,mysql,这算是边琢磨,边实践吧. 系列文章 [实战]MVC5+EF6+MySql ...

  2. 2.4scope

    name_scope variable_scope scope (name_scope/variable_scope) from __future__ import print_function im ...

  3. HDU 1789 - Doing Homework again - [贪心+优先队列]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1789 Time Limit: 1000/1000 MS (Java/Others) Memory Li ...

  4. JSTL 学习

    对于页面访问数据的统计,可以使用内置对象的相应方法进行计数工作,这个对象要在jsp对象的整个生命周期中setAttribute()和getAttribute()application.setAttri ...

  5. LINUX系统中安装ORACLE11g的安装文档,含部分问题解答

    1.无法使用命令 /usr/bin/xdpyinfo 自动检查显示器颜色 在linux as5下安装oracle11g,环境都配置好了!等运行./runInstaller的时候无法弹出安装的图形界面我 ...

  6. package-info.java https://www.intertech.com/Blog/whats-package-info-java-for/

    mybatis-3/src/main/java/org/apache/ibatis/cache/package-info.java What’s package-info.java for? http ...

  7. od --http://blog.csdn.net/hgy413/article/details/7711925

    http://blog.csdn.net/hgy413/article/details/7711925

  8. [python-opencv]图像二值化【图像阈值】

    图像二值化[图像阈值]简介: 如果灰度图像的像素值大于阈值,则为其分配一个值(可以是白色255),否则为其分配另一个值(可以是黑色0) 图像二值化就是将灰度图像上的像素值设置为0或255,也就是将整个 ...

  9. php页面获取数据库中的数据

    <!DOCTYPE HTML><html>    <head>        <meta charset="utf-8" />   ...

  10. android发短信,打电话

    //1.进入系统短信列表界面 Intent intent = newIntent(Intent.ACTION_MAIN); intent.addCategory(Intent.CATEGORY_DEF ...