MySQL 5.7发布后,在复制方面有了很大的改进和提升。比如开始支持多源复制(multi-source)以及真正的支持多线程复制了。多源复制可以使用基于二进制日子的复制或者基于事务的复制。下面我们说一说如何配置基于二进制日志的多源复制。

什么是多源复制???

首先,我们要清楚几种常见的复制模式:

一主一从

一主多从

级联复制

multi-master

MySQL 5.7 之前只能支持一主一从,一主多从或者多主多从的复制。如果想实现多主一从的复制 只能使用mariadb,但是mariadb又与官方的mysql版本不兼容。

MySQL 5.7 开始支持了多主一从的复制方式也就是多源复制。MySQL 5.7 版本相比之前的版本,无论是功能还是性能还是安全等方面都已经有了不少的提升。

首先我们要清楚multi-master OR multi-source 复制不是一样的。multi-master复制通常是环形的复制,可以在任意的主机上将数据复制给其他的主机。如图:

multi-source 是不同的。简单的说,多源复制就是将多个主库同步到一个从库,从而增加从的利用率,节省了机器。如图:

多源复制的使用场景

数据分析部门会需要各个业务部门的部分数据做数据分析,这个时候就可以使用到多源复制把各个主数据库的数据复制到统一的数据库中

在从服务器进行数据的汇总,如果我们的主服务器进行了分库分表的操作,为了实现后期的一些数据的统计功能,往往要把数据汇总在一起在进行统计

在从服务器对所有主服务器的数据进行备份,在MySQL 5.7之前每个主服务器都需要一台从服务器,这样很容易造成资源的浪费,同时也加大了DBA的维护成本,但MySQL 5.7引入的多源复制,可以把多个主服务器的数据同步到一台从服务器进行备份。

使用多源复制的必要条件

不管是使用基于二进制日志的复制或者基于事务的复制,要开启多源复制功能必须要在从库上设置master-info-repository AND relay-log-info-repository 这两个参数。

这两个参数是用来存储同步信息的,可以设置的值为FILE和TABLE,默认是FILE。比如master-info就保存在master.info文件中,relay-log-info保存在relay-log.inf文件中服务器如果意外关闭,正确的relay-log-info没有来的及更新带relay-log.info文件,这样就会造成数据的丢失。

为了数据更加安全,通常设置为TABLE。这些表都是innodb类型的,支持事务。相对文件存储安全得多。在MySQL库下可以看到这两个表的信息,分别是mysql.slave_master_info AND mysql.slave_relay_log_info 。

这两个参数也是可以动态调整的。

SET GLOBAL master_info_repository = 'TABLE';

SET GLOBAL relay_log_info_repository = 'TABLE';

如果要启用enhanced multi-threaded slave(多线程复制),可以设置一下参数

slave-parallel-type=LOGICAL_CLOCK

slave-parallel-workers=8

relay_log_recovery=ON

如果SLAVE已经为开启状态,那么需要首先关闭SLAVE(stop slave;)

配置多源复制

环境准备:

hostname

IP

mysql

dev-master-01

192.168.1.131

master

dev_node-01

192.168.1.132

master

dev-node-02

192.168.1.133

slave

安装MySQL 5.7版本:

可参考官方文档:https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html

MySQL 5.7软件包下载地址:https://dev.mysql.com/downloads/repo/yum/

下载yum源rpm安装包:wget https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

安装yum源:yum localinstall mysql57-community-release-el7-11.noarch.rpm

检查mysql源是否安装成功:yum repolist enable | grep "mysql.*-community.*"

安装MySqL:yum install mysql-community-server

启动MySQL服务:systemctl start mysqld

查看MySQL的启动状态:systemctl status mysqld

设置开机自启:systemctl enable mysqld ----> systemctl daemon-reload

修改root默认密码(这里出现了一些小问题)下面做问题的阐述

在修改密码的过程中出现了和官网上说法不一致的问题

官网的说法:

mysql安装完成后,在/var/log/mysqld.log文件中给root生成一个默认的密码,通过下面的方式可以找到root的默认密码,然后登录mysql进行修改:

找密码:grep 'temporary password' /var/log/mysqld.log

登录mysql:mysql -uroot -p

修改密码:ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!'

注意:MySQL的 validate_password 插件默认安装。这将要求密码至少包含一个大写字母,一个小写字母,一位数字和一个特殊字符,并且总密码长度至少为8个字符。

我自己遇到的问题:

使用官方提供的找密码的命令根本就在mysqld.log文件中找不到默认的密码,只能想办法自己解决mysql的密码的问题了 尝试了一些mysql5.7之前的版本的修改密码的方法但是还是不可行,但是最后还是想到了一种相当简单的方法:

修改/etc/my.cnf 在[mysqld]下面添加 skip-grant-tables=1 这一行配置 让mysql启动的时候不对密码进行验证

重启mysqld服务:systemctl restart mysqld

使用root用户登录到mysql:mysql -uroot

切换到mysql数据库:use mysql;

更新user表:UPDATE user SET authentication_string = PASSWORD('sycx_2009abc') WHERE user = 'root';

使修改后生效:FLUSH PRIVILEGES;

退出mysql,编辑/etc/my.cnf文件 注释掉skip-grant-tables=1

重启mysqld服务,再用新密码登录即可

配置多源复制:

上面我们已经把MySQL 5.7版本的mysql安装成功了 现在我们只要修改my.cnf配置文件重启mysql验证多源复制即可。步骤如下:

修改192.168.1.131和192.168.1.132下面的/etc/my.cnf文件,修改如下:记得修改配置参数中的server-id(192.168.1.131为1,那么192。168.1.132就得是2,每台服务器中的这个id不能一样,切记!!!)

[mysqld]

# 指定端口 不指定默认3306

#port=5603

# mysql数据存放路径

datadir=/var/lib/mysql

# mysql socker文件存放路径

socket=/var/lib/mysql/mysql.sock

# 创建符号链接(建议禁用符号链接,以防止各种安全风险。开启将参数的值设置为1)

symbolic-links=0

# 错误日志存放路径

log-error=/var/log/mysqld.log

# 启动pid文件存放路径

pid-file=/var/run/mysqld/mysqld.pid

# 设置主从的时候的唯一ID 每台主机的ID不可重复

server-id=1

# #打开日志(主机需要打开),这个mysql-bin也可以自定义,这里也可以加上路径,如:/home/www/mysql_bin_log/mysql-bin  

log-bin=mysql-bin

# 设定mysql的复制模式(STATEMENT  ROW  MIXED)

binlog_format=mixed

# 绕过密码验证可直接使用root登录(用于修改密码)

#skip-grant-tables=1

# 启动服务器来禁用主机名缓存

skip-host-cache

# 如果这个参数设为OFF,则MySQL服务在检查客户端连接的时候会解析主机名;如果这个参数设为ON,则MySQL服务只会使用IP,在这种情况下,授权表中的Host字段必须是IP地址或localhost。

skip-name-resolve

# 网络传输时单个数据包的大小

max_allowed_packet = 500M

# 设置数据库的时间

default-time-zone = '+8:00'

# 内部内存临时表的最大内存

tmp_table_size=200M

# MySQL服务器用来作普通索引扫描、范围索引扫描和不使用索引而执行全表扫描这些操作所用的缓存大小。

join_buffer_size = 32M

# 每个会话执行排序操作所分配的内存大小。

sort_buffer_size = 1M

# 每个客户端线程和连接缓存和结果缓存交互,每个缓存最初都被分配大小为net_buffer_length的容量,并动态增长,直至达到max_allowed_packet参数的大小

net_buffer_length = 8K

# 为每个线程对MyISAm表执行顺序读所分配的内存。如果数据库有很多顺序读,可以增加这个参数,默认值是131072字节。

read_buffer_size = 512K

# 这个参数用在MyISAM表和任何存储引擎表随机读所使用的内存。

read_rnd_buffer_size = 32M

# 在REPAIR TABLE、CREATE INDEX 或 ALTER TABLE操作中,MyISAM索引排序使用的缓存大小。

myisam_sort_buffer_size = 256M

# 设置客户端的并发连接数量

max_connections = 8000

# mysql关闭非交互连接前的等待时间,单位是秒

wait_timeout = 604800

# Mysql关闭交互连接前的等待时间,单位是秒

interactive_timeout = 604800

# 设定远程用户必须回应PORT类型数据连接的最大时间

connect_timeout = 30

# 如果客户端尝试连接的错误数量超过这个参数设置的值,则服务器不再接受新的客户端连接。可以通过清空主机的缓存来解除服务器的这种阻止新连接的状态,通过FLUSH HOSTS或mysqladmin flush-hosts命令来清空缓存。

max_connect_errors = 30000

# mysql关闭连接前的等待时间,单位是秒

interactive_timeout = 86400

# 慢查询的时间设置,单位为秒

long_query_time = 20

# mysql服务缓存以重用的线程数

thread_cache_size = 120

# 为查询结果所分配的缓存

query_cache_size = 256M

# 如果一个事务需要的内存超过这个参数,就会报错

max_heap_table_size=2097152000

  

2、修改192.168.1.133也就是从库的/etc/my.cnf 配置参数,配置如下:(记得修改server-id为3,不能和其他服务器id一样,切记!!!)

[mysqld]

# 指定端口 不指定默认3306

#port=5603

# mysql数据存放路径

datadir=/var/lib/mysql

# mysql socker文件存放路径

socket=/var/lib/mysql/mysql.sock

# 创建符号链接(建议禁用符号链接,以防止各种安全风险。开启将参数的值设置为1)

symbolic-links=0

# 错误日志存放路径

log-error=/var/log/mysqld.log

# 启动pid文件存放路径

pid-file=/var/run/mysqld/mysqld.pid

# 设置主从的时候的唯一ID 每台主机的ID不可重复

server-id=1

# #打开日志(主机需要打开),这个mysql-bin也可以自定义,这里也可以加上路径,如:/home/www/mysql_bin_log/mysql-bin  

log-bin=mysql-bin

# 设定mysql的复制模式(STATEMENT  ROW  MIXED)

binlog_format=mixed

# 绕过密码验证可直接使用root登录(用于修改密码)

#skip-grant-tables=1

# 启动服务器来禁用主机名缓存

skip-host-cache

# 如果这个参数设为OFF,则MySQL服务在检查客户端连接的时候会解析主机名;如果这个参数设为ON,则MySQL服务只会使用IP,在这种情况下,授权表中的Host字段必须是IP地址或localhost。

skip-name-resolve

# 网络传输时单个数据包的大小

max_allowed_packet = 500M

# 设置数据库的时间

default-time-zone = '+8:00'

# 内部内存临时表的最大内存

tmp_table_size=200M

# MySQL服务器用来作普通索引扫描、范围索引扫描和不使用索引而执行全表扫描这些操作所用的缓存大小。

join_buffer_size = 32M

# 每个会话执行排序操作所分配的内存大小。

sort_buffer_size = 1M

# 每个客户端线程和连接缓存和结果缓存交互,每个缓存最初都被分配大小为net_buffer_length的容量,并动态增长,直至达到max_allowed_packet参数的大小

net_buffer_length = 8K

# 为每个线程对MyISAm表执行顺序读所分配的内存。如果数据库有很多顺序读,可以增加这个参数,默认值是131072字节。

read_buffer_size = 512K

# 这个参数用在MyISAM表和任何存储引擎表随机读所使用的内存。

read_rnd_buffer_size = 32M

# 在REPAIR TABLE、CREATE INDEX 或 ALTER TABLE操作中,MyISAM索引排序使用的缓存大小。

myisam_sort_buffer_size = 256M

# 设置客户端的并发连接数量

max_connections = 8000

# mysql关闭非交互连接前的等待时间,单位是秒

wait_timeout = 604800

# Mysql关闭交互连接前的等待时间,单位是秒

interactive_timeout = 604800

# 设定远程用户必须回应PORT类型数据连接的最大时间

connect_timeout = 30

# 如果客户端尝试连接的错误数量超过这个参数设置的值,则服务器不再接受新的客户端连接。可以通过清空主机的缓存来解除服务器的这种阻止新连接的状态,通过FLUSH HOSTS或mysqladmin flush-hosts命令来清空缓存。

max_connect_errors = 30000

# mysql关闭连接前的等待时间,单位是秒

interactive_timeout = 86400

# 慢查询的时间设置,单位为秒

long_query_time = 20

# mysql服务缓存以重用的线程数

thread_cache_size = 120

# 为查询结果所分配的缓存

query_cache_size = 256M

# 如果一个事务需要的内存超过这个参数,就会报错

max_heap_table_size=2097152000

# mysql5.7 多源复制从库的配置参数

master-info-repository = table # 这个参数是必须的

relay-log-info-repository = table # 这个参数是必须的

report-port = 3306

report-host = 192.168.1.131

replicate-do-db = master1

replicate-do-db = master2

replicate_wild_do_table=master1.%

replicate_wild_do_table=master2.%

3、重新启动mysql服务:systemctl restart mysqld

4、升级mysql授权表:mysql_upgrade -uroot -p

5、登录192.168.1.131和192.168.1.132的mysql:mysql -uroot -p

6、以下的执行都是在192.168.1.131和192.168.1.132的mysql中执行sql语句

创建mysql的主从授权用户:grant replication slave on *.*  to 'slave'@'192.168.1.%' identified by '2017123';

刷新生效:FLUSH PRIVILEGES;

7、登录192.168.1.133的mysql执行sql语句:

CHANGE MASTER TO MASTER_HOST='192.168.1.131',

MASTER_USER='slave',

MASTER_PORT=3306,

MASTER_PASSWORD='2017123',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=1 FOR CHANNEL 'master1';

CHANGE MASTER TO MASTER_HOST='192.168.1.132',

MASTER_USER='slave',

MASTER_PORT=3306,

MASTER_PASSWORD='2017123',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=1 FOR CHANNEL 'master2';

  

8、全部显示sql语句执行ok,然后查看主从的状态:

执行sql语句:show  slave  status\G;

如果要查看单一信道的复制的详细状态,可以使用以下命令:

SHOW SLAVE STATUS FOR CHANNEL 'master1'\G;

9、在主库(192.168.1.131)实例创建一些数据。

create database master1;

use master1;

CREATE TABLE `test1` (`id` int(11) DEFAULT NULL,`count` int(11) DEFAULT NULL);

insert into test1 values(1,1);

  

10、在主库(192.168.1.132)实例创建一些数据。

create database master2;

use master2;

CREATE TABLE `test2` (`id` int(11) DEFAULT NULL,`count` int(11) DEFAULT NULL);

insert into test2 values(1,1);

  

11、在从库(192.168.1.133)实例检查数据是否成功复制。

select * from master1.test1;

select * from master2.test2;

  

12、列出所有的复制信道的复制状态概况:

select * from performance_schema.replication_applier_status_by_worker;

  

13、在 performance_schema 库中,提供了复制相关的一些视图,可供查看复制相关的信息。

use performance_schema;

show tables like '%repl%';

这些表里分别有多源通道的配置信息和多源通道的状态信息,另外还有连接配置信息和连接状态信息,如果配置了多线程复制的话,还会有多线程配置信息和多线程状态信息。

其它一些需要注意的点:

初次配置耗时较长,需要将各个 master 的数据 dump 下来,再 source 到 slave 上。

需要考虑各 master 数据增长频率,slave 的数据增长频率是这些数据的总和。如果太高,会导致大量的磁盘IO,造成数据更新延迟,最严重的是会影响正常的查询。

如果多个主数据库实例中存在同名的库,则同名库的表都会放到一个库中;

如果同名库中的表名相同且结构相同,则数据会到一起;如果结构不同,则先建的有效。

mysql5.7 安装和多源复制实践的更多相关文章

  1. MySQL 5.7 多源复制实践

    多源复制使用场景 数据分析部门会需要各个业务部门的部分数据做数据分析,这个时候就可以用到多源复制把各个主数据库的数据复制到统一的数据库中. 在从服务器进行数据汇总,如果我们的主服务器进行了分库分表的操 ...

  2. MySQL5.7多源复制实践

    MySQL5.7开始新增多源复制功能,即允许一个salve同时复制多个主库的事务,slave会创建通往每个主库的管道.多源复制在应用来自多个源的事务的时候不会对有冲突的事务进行检测. 配置实现 主库支 ...

  3. MySql5.7-多源复制(多主单从)

    1.1.主库配置 my.cnf   #确保唯一 server-id=1 #作为Master要开启binlog log-bin=mysql-bin #binlog format有三种形式:Stateme ...

  4. MySQL5.7多源复制

    MySQL5.7开始支持多源复制,也就是多主一从的复制架构: 使用多源复制的考虑: 1.灾备作用:将各个库汇总在一起,就算是其他库都挂了(整个机房都无法连接了),还有最后一个救命稻草: 2.备份:直接 ...

  5. MySQL 多源复制(Mulit-Source Replication)

    MySQL多源复制方案        看复制源Master_1的同步状态:SHOW SLAVE STATUS FOR CHANNEL 'Master_1'\G 查看复制源Master_2的同步状态:S ...

  6. MySQL5.7多主一从(多源复制)同步配置

    MySQL5.7多主一从(多源复制)同步配置(抄袭) 原文地址:https://my.oschina.net/u/2399373/blog/2878650 多主一从,也称为多源复制,数据流向: 主库1 ...

  7. MySQL5.7之多源复制&Nginx中间件(上)【转】

    有生之年系列----MySQL5.7之多源复制&Nginx中间件(上)-wangwenan6-ITPUB博客http://blog.itpub.net/29510932/viewspace-1 ...

  8. MySQL5.7之多源复制&Nginx中间件(下)【转】

    有生之年系列----MySQL5.7之多源复制&Nginx中间件(下)-wangwenan6-ITPUB博客http://blog.itpub.net/29510932/viewspace-1 ...

  9. MySQL5.7 多源复制监控脚本

    #!/bin/bash :<<BLOCK Version : v1.0 2018-12-21 MySQL多源复制检测脚本 监控配置放在 $CONFIG_FILE 中,内容如下 #mysql ...

随机推荐

  1. ASP.NET MVC 异常Exception拦截

    一.前言 由于客户端的环境不一致,有可能会造成我们预计不到的异常错误,所以在项目中,友好的异常信息提示,是非常重要的.在asp.net mvc中实现异常属性拦截也非常简单,只需要继承另一个类(Syst ...

  2. 聊聊我面试过的一个最奇葩的 Java 程序猿!

    上周我聊了聊最让我反感的 10 种程序猿,无奈一个小时就进行了删除,详细原因就不说了,容易招黑. 今天聊的我面试过的最奇葩的一个程序猿,绝对是奇葩中的奇葩,简直是程序猿中的另类,最让我反感的程序猿又添 ...

  3. Django Rest Swagger生成api文档

    关于swagger Swagger能成为最受欢迎的REST APIs文档生成工具之一,有以下几个原因: Swagger 可以生成一个具有互动性的API控制台,开发者可以用来快速学习和尝试API. Sw ...

  4. spring boot -thymeleaf-遍历list和map

    遍历 list如下 th:each th:each 状态变量 var 遍历map如下(需要双层遍历) controller代码如下

  5. Java 基础学习总结(一)抽象类和接口

    接触java的时间不是很长,以前对抽象类和接口的定义和区别也是模糊不清,最近拿起学校的教程读了起来,也参阅了网上的博客大神理解和总结,于是决定自己按照自己的理解来总结一下. 抽象类(半成品)   一般 ...

  6. Fork/Join框架

    java 5开始引入了Executor和ExecutorService接口以及实现这两个接口的类之后,使得java在并发支持上得到了进一步的提升.执行器框架(Executor Framework)将任 ...

  7. NGINX 加载动态模块(NGINX 1.9.11开始增加加载动态模块支持)

    NGINX 1.9.11开始增加加载动态模块支持,从此不再需要替换nginx文件即可增加第三方扩展.目前官方只有几个模块支持动态加载,第三方模块需要升级支持才可编译成模块. tinywan@tinyw ...

  8. ContextLoaderListener可以不写嘛?

    写了那么久的Spring,经常写这样的配置,这就是几行Spring.SpringMvc的基本配置, 但是最近也看到不写最前面的context-param以及listener的,好奇记录下. <c ...

  9. Hibernate学习(一)———— 第一个hibernate工程

    一.什么是Hibernate? 轻量级JavaEE应用的持久层框架,是一个完全的ORM框架.(说完这句话,肯定有很多人懵圈了,下面我来一个个解释) 持久化:将我们想要保存的数据保存到硬盘上,也就是我们 ...

  10. webpack4打包报错:WARNING in configuration The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults fo

    运行命令webpack ./src/main.js ./dist/murenziwei.js后,目录上神马动静都没有,你以为在dist文件夹上会有murenziwei.js吗?毛都没有 警告和错误倒是 ...