一、简单主从模式配置步骤(必须要mysql5.6,此处以maridb10.0.10为例)

1、配置主从节点的服务配置文件
# vim /etc/my.cnf

1.1、配置master节点:

[mysqld]
log-bin=/data/binlogs/master-bin
binlog_format=row

server-id       = 100
log-slave-updates = True
#gtid-mode = ON
#enforce-gtid-consistency=True
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info = 1
slave-parallel-threads = 2
binlog-checksum = CRC32
master-verify-checksum = 1
slave-sql-verify-checksum = 1
binlog-rows-query-log-events = 1
report-port = 3306
report-host = master.chinasoft.com

1.2、配置slave节点:

[mysqld]
log-bin=/data/binlogs/master-bin
binlog_format=row

server-id       = 200
log-slave-updates = True
#gtid-mode = ON
#enforce-gtid-consistency=True
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info = 1
slave-parallel-threads = 2
binlog-checksum = CRC32
master-verify-checksum = 1
slave-sql-verify-checksum = 1
binlog-rows-query-log-events = 1
report-port = 3306
report-host = slave.chinasoft.com

修改文件报错可参考/data/mydata/下的错误日志定位
# tail centossz008.err

修改master的hostname
在hosts文件中添加master和slave的解析,将传给slave
192.168.8.40 master.chinasoft.com master
192.168.8.43 slave.chinasoft.com slave

# hostname master.chinasoft.com

# vim /etc/hosts

# scp /etc/hosts 192.168.8.42:/etc/

配置中可能碰到的错误:

2、创建复制用户

主服务器192.168.8.40:
MariaDB [(none)]> GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO 'repluser'@'192.168.%.%' IDENTIFIED BY 'replpass';

MariaDB [(none)]> FLUSH PRIVILEGES;

说明:192.168.%.% 是从节点服务器;如果想一次性授权更多的节点,可以自行根据需要修改;

3、为备节点提供初始数据集

锁定主表,备份主节点上的数据,将其还原至从节点;如果没有启用GTID,在备份时需要在master上使用show master status命令查看二进制日志文件名称及事件位置,以便后面启动slave节点时使用。
# mysqldump --all-databases --lock-all-tables --flush-logs --master-data=2 > all.sql
传给从服务器
# scp all.sql:192.168.8.43

4、启动从节点的复制线程

普通主从复制:

MariaDB [(none)]> CHANGE MASTER TO MASTER_HOST='192.168.8.40',MASTER_USER='repluser',MASTER_PASSWORD='replpass',MASTER_LOG_FILE='master-bin.000004',MASTER_LOG_POS=379;

启用GTID,需要使用如下命令:

MariaDB [(none)]> CHANGE MASTER TO MASTER_HOST='192.168.8.40',MASTER_USER='repluser',MASTER_PASSWORD='replpass',MASTER_USE_GTID=current_pos;


MariaDB [(none)]> start slave;
查看从服务器状态

MariaDB [(none)]> show slave status\G

可以通过在主服务器中导入一张大的数据表(总数量在4W行左右),通过从服务器观察是否启用了多线程复制:

主服务器:

MariaDB [db1]> CREATE TABLE `ehr_user` (   `LOB_NUMBER` varchar(255) NOT NULL,   `SEX` varchar(255) DEFAULT '',   `LAST_NAME` varchar(255) DEFAULT NULL,   `EMPLOYEE_NUMBER` varchar(255) DEFAULT NULL,   `PHONE` varchar(255) DEFAULT NULL,   `NATIONAL_IDENTIFIER`
varchar(255) DEFAULT NULL,   `EMAIL` varchar(255) DEFAULT NULL,   `LOB_GROUP` varchar(255) DEFAULT NULL,   `LOB` varchar(255) DEFAULT NULL,   `BUG` varchar(255) DEFAULT NULL,   `BUDU` varchar(255) DEFAULT NULL,   `DD` varchar(255) DEFAULT NULL,   `REGION`
varchar(255) DEFAULT NULL,   `DS` varchar(255) DEFAULT NULL,   `PEOPLE_TYPE` varchar(255) DEFAULT NULL,   `ACTUAL_TERMINATION_DATE` varchar(255) DEFAULT NULL,   `HIRE_DATE` timestamp NULL DEFAULT NULL,   `FLAG` varchar(8) CHARACTER SET gbk COLLATE gbk_bin
DEFAULT '0',   `LAST_UPDATETIME` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,   `EMAIL_NO_LOGIN` varchar(8) DEFAULT NULL,   `LOB_NUMBER_BAK` varchar(255) DEFAULT NULL,   PRIMARY KEY (`LOB_NUMBER`),   KEY `EMPLOYEE_NUMBER` (`EMPLOYEE_NUMBER`),  
KEY `FLAG` (`FLAG`) USING BTREE,   KEY `LOB` (`LOB`) USING BTREE ) ENGINE=MyISAM DEFAULT CHARSET=gbk;

MariaDB [db1]> source /root/ehr_user.sql

从服务器通过命令观察:

# watch -n .3 "mysql -e 'show processlist\G'"

# watch -n .5 "mysql -e 'show slave status\G'"

报错:
Last_IO_Error: error connecting to master 'repluser@192.168.8.40:3306' - retry-time: 60  retries: 86400  message: Can't connect to MySQL server on '192.168.8.40' (113 "No route to host")

发现是被防火墙阻挡了,在主服务器关闭防火墙
# service iptable stop

验证测试:

通过在主服务器上创建数据库、表,能否在从服务器看到

多主复制:

主服务器1: 192.168.8.40
主服务器2:192.168.8.43
从服务器:192.168.8.44

配置主服务器2:

MariaDB [(none)]> GRANT REPLICATION SLAVE,REPLICATION CLIENT ON *.* TO 'repluser'@'192.168.%.%' IDENTIFIED BY 'replpass';

配置从服务器192.168.8.44:
修改配置文件
vim /etc/my.cnf

加入
relay-log=/data/binlogs/relay-bin
server-id       = 300
注释掉
# bin-log=master-bin

重启服务

# service mysqld restart

MariaDB [(none)]> CHANGE MASTER 'm1' TO MASTER_HOST='192.168.8.40',MASTER_USER='repluser',MASTER_PASSWORD='replpass';
MariaDB [(none)]> CHANGE MASTER 'm2' TO MASTER_HOST='192.168.8.43',MASTER_USER='repluser',MASTER_PASSWORD='replpass';

启动服务:

MariaDB [db1]> start all slaves;

观察服务是否启动正常:

MariaDB [(none)]> show slave 'm2' status\G

MariaDB [(none)]> show slave 'm1' status\G

报错:

Last_SQL_Error: Error 'Can't create database 'mydb'; database exists' on query. Default database: 'mydb'. Query: 'create database mydb'

解决方法:

主服务器m1:

从服务器执行(192.168.8.44):

MariaDB [(none)]> STOP SLAVE 'm1';

MariaDB [(none)]> CHANGE MASTER 'm1' TO MASTER_HOST='192.168.8.40',MASTER_USER='repluser',MASTER_PASSWORD='replpass',MASTER_LOG_FILE='master-bin.000007',MASTER_LOG_POS=335;

再次验证OK

MariaDB基于GTID主从复制及多主复制的更多相关文章

  1. Centos7.5部署MySQL5.7基于GTID主从复制+并行复制+半同步复制+读写分离(ProxySQL) 环境- 运维笔记 (完整版)

    之前已经详细介绍了Mysql基于GTID主从复制的概念,原理和配置,下面整体记录下MySQL5.7基于GTID主从复制+并行复制+增强半同步复制+读写分离环境的实现过程,以便加深对mysql新特性GT ...

  2. 企业级-Mysql双主互备高可用负载均衡架构(基于GTID主从复制模式)(原创)

    前言:          原理与思想        这里选用GTID主从复制模式Mysql主从复制模式,是为了更加确保主从复制的正确性.健康性与易配性.这里做的是两服务器A,B各有Mysql实例331 ...

  3. MySQL 5.7 基于GTID主从复制+并行复制+半同步复制

    环境准备 IP HOSTNAME SERVICE SYSTEM 192.168.131.129 mysql-master1 mysql CentOS7.6 192.168.131.130 mysql- ...

  4. Mysql基于GTID主从复制

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

  5. mysql主从复制及双主复制

    之前做过一次在单台机器上的多实例的mysql,这次分开做,使用两台主机. 这里使用的主机地址分别为: MASTER:192.168.214.135 SLAVE  : 192.168.214.128 这 ...

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

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

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

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

  8. Mysql5.7实现主从复制、基于GTID的主从复制、并行复制

    (一.主从复制) 一.mysql主从复制原理    mysql的默认复制方式是主从复制.Mysql内建的复制功能是构建大型,高性能应用程序的基础.将Mysql的数据分布到多个系统上去,这种分布的机制, ...

  9. 实现mysql的读写分离(mysql-proxy)____1(mysql的主从复制,基于gtid的主从复制,半同步复制,组复制)

    主从复制原理: 从库生成两个线程,一个I/O线程,一个SQL线程: i/o线程去请求主库 的binlog,并将得到的binlog日志写到relay log(中继日志) 文件中:主库会生成一个 log ...

随机推荐

  1. 使用ADO.NET操作Oracle数据库

    本文将示例使用C#的ADO.NET技术调用Oralce的存储过程和函数及操作Oracle数据库. 在oracle的hr数据库中建立存储过程 在oralce的hr数据库中建立函数 新建控制台项目,在主函 ...

  2. POJ 1459 Power Network / HIT 1228 Power Network / UVAlive 2760 Power Network / ZOJ 1734 Power Network / FZU 1161 (网络流,最大流)

    POJ 1459 Power Network / HIT 1228 Power Network / UVAlive 2760 Power Network / ZOJ 1734 Power Networ ...

  3. “由于下列错误,Parallel port driver 服务启动失败”,注意了

    最近在“事件查看器”中发现这么一个错误:“由于下列错误,Parallel port driver 服务启动失败”, 我到网上搜索了一下,发现很多网页上都说解决办法: 把HKEY_LOCAL_MACHI ...

  4. MATLAB:图像水平、垂直、水平垂直镜像、转置、旋转变换(flipdim、mirror、transp、imrotate函数)

    1.原图像经水平.垂直.水平垂直镜像设置通过mirror函数实现: close all; %关闭当前所有图形窗口,清空工作空间变量,清除工作空间所有变量 clear all; clc; I=imrea ...

  5. 2018年湘潭大学程序设计竞赛 H统计颜色

    链接:https://www.nowcoder.com/acm/contest/105/H来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536 ...

  6. (java保留n位小数)precise math function 北京信息科技大学第十届ACM程序设计竞赛 第2题

    precise math function Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Othe ...

  7. 自动清理MySQL binlog日志

    开启MySQL binlog日志的服务器,如果不设置自动清理日志,默认binlog日志一直保留着,时间一长,服务器磁盘空间被binlog日志占满,导致MySQL数据库出错. 使用下面方法可以安全清理b ...

  8. ​python高级数据可视化视频Dash1

    在谷歌浏览器输入http://127.0.0.1:8050/后,回车,看到下图可视化结果 # -*- coding: utf-8 -*- """ Created on S ...

  9. python 压缩文件为zip后删除原文件

    压缩.log 文件为zip后删除原文件 需要注意:本人作为小白,该脚本需要和.log在一起,后面有时间需要改正. #!/usr/local/python/bin/python #-*-coding=u ...

  10. Hbase记录-Hbase其他工具

    1.RowCounter工具可以查看某张表有多少行,效率非常高 2.count命令在数据量大的时候效率非常差 执行./hbase  org.apache.hadoop.habse.mapreduce. ...