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实现数据库主从复制主主复制半同步复制的主要内容,如果未能解决你的问题,请参考以下文章