Mysql实现数据库主从复制主主复制半同步复制

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql实现数据库主从复制主主复制半同步复制相关的知识,希望对你有一定的参考价值。

--------------mysql实现数据库主从复制架构----------------

一、环境准备:

centos系统服务器2台、一台用户做Mysql主服务器,一台用于做Mysql从服务器,配置好yum源、防火墙关闭、各节点时钟服务同步、各节点之间可以通过主机名互相通信

192.168.41.145   master

192.168.41.137  slave

二、准备步骤:

1、iptables -F && setenforce 清空防火墙策略,关闭selinux

2、①vim /etc/hosts

192.168.41.145   master     #各节点之间可以通过主机名互相通信

192.168.41.137  slave

② ntpdate 172.17.0.1  #各节点时钟服务同步

3、拿两台服务器都使用yum方式安装Mysql服务,要求版本一致

4、分别启动两台服务器mysql服务,确保服务正常.

三、实现步骤:

1、配置master主服务器

对master进行配置,包括打开二进制日志,指定唯一的servr ID。例如,在配置文件加入如下值。

vim /etc/my.cnf

server-id=1 #配置server-id,让主服务器有唯一ID号

log-bin=mysql-bin #打开Mysql日志,日志格式为二进制

skip-name-resolve#关闭名称解析,(非必须)

2.创建复制帐号

在Master的数据库中建立一个备份帐户:每个slave使用标准的MySQL用户名和密码连master 。进行复制操作的用户会授予REPLICATION SLAVE权限。

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO [email protected]'192.168.%.%' IDENTIFIED BY 'ke';

3.查看主服务器状态

在Master的数据库执行show master status,查看主服务器二进制日志状态

技术分享图片技术分享图片

4、配置slave从服务器

对slave进行配置,打开中继日志,指定唯一的servr ID,设置只读权限。在配置文件加入如下值

server-id=2 #配置server-id,让从服务器有唯一ID号

relay_log = mysql-relay-bin #打开Mysql日志,日志格式为二进制

read_only = 1 #设置只读权限

log_bin = mysql-bin #开启从服务器二进制日志

log_slave_updates = 1 #使得更新的数据写进二进制日志中

5.启动从服务器复制线程

①stop  slave;

②reset slave;

③让slave连接master,并开始重做master二进制日志中的事件。

CHANGE MASTER TO

MASTER_HOST='192.168.41.145',

MASTER_USER='slave',

MASTER_PASSWORD='ke', 【主从密码要一致】

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=278;

※注意

IP为master的IP;

密码和master设置一致;

POS设置查看master得到:show master status

④start slave;# 启动复制线程。

6、查看从服务器状态

可使用SHOW SLAVE STATUS\G查看从服务器状态,如下所示,也可用show processlist \G查看当前复制状态:

Slave_IO_Running: Yes #IO线程正常运行

Slave_SQL_Running: Yes #SQL线程正常运行

【两者必须同时YES,才算启动成功】

附:主从同步出现一下错误:

Slave_IO_Running: Connecting

Slave_SQL_Running: Yes

解决方法:

导致lave_IO_Running 为connecting 的原因主要有以下 3 个方面:

  1、网络不通

2、密码不对

3、pos不对

四、验证

在master上插入数据,查看slave上是否可以同步

create database liuke;#建数据库

use liuke;

create table mini_tb(id int(3),name char(10));  #建表

insert into mini_tb values(001,'candy'); #插入数据

select*from mini_tb;     #查看表内容

技术分享图片技术分享图片

在slave上查看,可以同步则成功。

五、添加新slave服务器

假如master已经运行很久了,想对新安装的slave进行数据同步,甚至它没有master的数据。

此时,有几种方法可以使slave从另一个服务开始,例如,从master拷贝数据,从另一个slave克隆,从最近的备份开始一个slave。为了加快Slave与master同步,可

用以下方式先进行数据同步:

(1)master的某个时刻的数据快照;

(2)数据库的备份数据

(3)master的二进制日志文件。

--------------mysql实现数据库主主复制----------------

一、原理

主主复制即在两台MySQL主机内都可以变更数据,而且另外一台主机也会做出相应的变更。

如何实现:就是将两个主从复制有机合并起来。

配置的时候需要注意的问题:主键重复,server-id不能重复。

二、实验步骤

master:192.168.41.145   slave:192.168.41.137

1、配置文件

定义master使用奇数id

vim   /etc/my.cnf

auto_increment_offset=1    #起始值。一般填第n台主MySQL。此时为第一台主MySQL

auto_increment_increment=2    #步进值auto_imcrement。一般有n台主MySQL就填n

slave 使用偶数id

auto_increment_offset=2

auto_increment_increment=2

2、   因为主主复制是两个主从复制组合一起,所以就接着上面主从复制接着配置。

(1)

①在slave上创建一个192.168.41.145主机可以登录的MySQL用户。

用户:bubu   密码:123

②创建:create user 'bubu'@'192.168.41.145' IDENTIFIED BY "123";

授权:grant replication slave on *.* to 'bubu'@'192.168.41.145' IDENTIFIED BY "123";

mysql>FLUSH PRIVILEGES;

③在192.168.41.137上查看二进制名和位置:show master status;

技术分享图片技术分享图片

技术分享图片

(3) 告知二进制文件名与位置

在192.168.41.145中执行:

change master to  master_host='192.168.41.137',

master_user='bubu',

master_password='123',

master_log_file='mysql-bin.000004',

master_log_pos=601;

主主复制配置完成。

三、测试

(1)

两个主机分别启动slave:start slave;

分别查看slave状态:

192.168.41.145     【replicate-do-db=aa #要同步的数据库,默认所有库】

技术分享图片技术分享图片

192.168.41.137

技术分享图片技术分享图片

当看到Slave_IO_Running: YES、Slave_SQL_Running: YES才表明状态正常

(2)

①192.168.41.145

MariaDB [mysql]> use jesper;

create table tab1(id int);

insert into tab1  values('66');

select*from tab1;

②192.168.41.145

MariaDB [mysql]> use jesper;

insert into tab1  values('99');

select*from tab1;

查看数据: 两个主机数据结果一样!

技术分享图片技术分享图片

※注意:

1、主主复制配置文件中auto_increment_increment和auto_increment_offset只能保证主键不重复,却不能保证主键有序。

2、当配置完成Slave_IO_Running、Slave_SQL_Running不全为YES时,show slave status\G信息中有错误提示,可根据错误提示进行更正。

常见出错点:

1、两台数据库都存在db数据库,而第一台MySQL db中有tab1,第二台MySQL db中没有tab1,那肯定不能成功。

2、已经获取了数据的二进制日志名和位置,又进行了数据操作,导致POS发生变更。在配置CHANGE MASTER时还是用到之前的POS。

3、stop slave后,数据变更,再start slave。出错。

终极更正法:重新执行一遍CHANGE MASTER就好了

--------------MySQL实现数据库半同步复制-------------

半同步复制模式必须在主服务器和从服务器同时中开启,否则将会默认为异步复制模式。

一、环境准备

①需要安装方可使用:

mysql> INSTALL PLUGIN plugin_name SONAME 'shared_library_name';

半同步复制:

semisync_master.so

semisync_slave.so

②检查是否有自动加载功能

MariaDB [(none)]> show variables like 'have_dynamic_loading';

技术分享图片技术分享图片

③主从复制已经配置好,并且已经工作。

二、实验步骤

1、主节点设置:

①安装:INSTALL PLUGIN rpl_semi_sync_master SONAME 'semisync_master.so';

②查看:MariaDB [mydb]> SHOW GLOBAL VARIABLES LIKE 'rpl_semi%';#查看半同步复制文件

+------------------------------------+-------+

| Variable_name | Value |

+------------------------------------+-------+

| rpl_semi_sync_master_enabled | OFF |

| rpl_semi_sync_master_timeout | 10000 |

| rpl_semi_sync_master_trace_level | 32 |

| rpl_semi_sync_master_wait_no_slave | ON |

+------------------------------------+-------+

③MariaDB [mydb]> SET GLOBAL rpl_semi_sync_master_enabled=ON;【0:关闭;1:开启】

#开启半同步复制,默认是关闭的。

2、从节点设置:

①INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so';

②MariaDB [mydb]> SHOW GLOBAL VARIABLES LIKE 'rpl_semi%';#查看是否加载成功

+---------------------------------+-------+

| Variable_name | Value |

+---------------------------------+-------+

| rpl_semi_sync_slave_enabled | OFF |

| rpl_semi_sync_slave_trace_level | 32 |

+---------------------------------+-------+

③重启从服务器IO线程,手动将异步模式换成半同步模式

MariaDB [mydb]> STOP SLAVE IO_THREAD;

MariaDB [mydb]> SET GLOBAL  rpl_semi_sync_slave_enabled = ON ;

MariaDB [mydb]> SHOW GLOBAL VARIABLES LIKE 'rpl_semi%';

MariaDB [mydb]> START SLAVE IO_THREAD;

※可查看从库错误日志观察是否生效

3、配置文件修改

主从配置文件都添加:

vim /etc/my.cnf

rpl_semi_sync_master_enabled=1 #表示以后启动MySQL将会自动开启半同步复制

三、测试

摸拟slave挂掉,master等待10s仍没接收到反馈信号,则转为异步复制模式,继续执行。

首先同步创建数据库aa

1、slave执行stop slave;关闭主从复制

2、master在aa数据库中创建表aihao,没接收到反馈信号,等待十秒后(Rpl_semi_sync_master_timeout=1000等待超时),继续执行

 master:

技术分享图片技术分享图片

slave:

技术分享图片技术分享图片

3、master在数据库中再创建tab2,不需要等待反馈,直接执行

【当反馈超时时,master将切换到异步复制模式。此时是异步模式,不需要等待】

技术分享图片技术分享图片

4、slave执行start slave,数据开始同步,建立aihao、tab2,反馈给master,并切换为半同步复制

技术分享图片技术分享图片

 5、slave执行stop slave;关闭主从复制

 6、master在数据库中创建表tab3,此时需要等待10s,接收slave反馈信号;等待超时,切换为异步复制模式,继续执行【步骤4时,数据同步已经反馈给master,此时master已经是半同步复制模式】

技术分享图片技术分享图片

以上是关于Mysql实现数据库主从复制主主复制半同步复制的主要内容,如果未能解决你的问题,请参考以下文章

mysql的主从主主及半同步复制

搭建MySQL的主从半同步主主复制架构

MySQL数据的主从复制半同步复制和主主复制详解

MySQL数据的主从复制半同步复制和主主复制详解

MySQL数据的主从复制半同步复制和主主复制详解

mysql主从和mysql主主和半同步复制