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已经是半同步复制模式】

时间: 2024-11-05 13:33:52

Mysql实现数据库主从复制、主主复制、半同步复制的相关文章

MySQL 5.7 新特性之增强半同步复制

1. 背景介绍 半同步复制 普通的replication,即mysql的异步复制,依靠mysql二进制日志也即binary log进行数据复制.比如两台机器,一台主机(master),另外一台是从机(slave). 正常的复制为:事务一(t1)写入binlog buffer:dumper 线程通知slave有新的事务t1:binlog buffer 进行checkpoint:slave的io线程接收到t1并写入到自己的的relay log:slave的sql线程写入到本地数据库. 这时,mast

MariaDB数据库主从复制、双主复制、半同步复制、基于SSL的安全复制实现及其功能特性介绍

一.复制概述 MariaDB/MySQL内建的复制功能是构建大型,高性能应用程序的基础.将MySQL的数据分布到多个系统上去,这种分布的机制,是通过将MySQL的某一台主机的数据复制到其它主机(slaves)上,并重新执行一遍来实现的.复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器.主服务器将更新写入二进制日志文件,并维护文件的一个索引以跟踪日志循环.这些日志可以记录发送到从服务器的更新.当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位

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

一.准备(主从都需要配置):     yum -y install mysql mysql-server #安装mysql   yum -y install ntpdate #安装时间同步   echo '*/1 * * * * /usr/sbin/ntpdate ntp1.aliyun.com &>/dev/null' >>/var/spool/cron/root #配置网络时间同步   service mysqld start #启动服务   chkconfig --add 

数据库 之 Mysql半同步复制

1  概述 半同步复制指一部分主机同步复制,另一部分主机异步复制 同步的逻辑是用户写操作到主服务器,主服务记录到二进制文件后,主服务会同步发送给从服务器,从服务器响应数据同步后,主服务器才会把响应发给用户.这种方式对IO有强依赖. mysql是高度插件化的,半同步复制插件是google共献给mysql的插件.装有该插件的服务器才能实现同步复制.半同步复制的插件在主节点和从节点是不一样的,各自分别使用专有插件,当插件配置启用后,从节点将同步的方式来同步主服务器数据,其他没有配置的插件的机器为异步同

MaridDB主从复制,双主模型,半同步的配置

一.主从复制 MariaDB是将客户端上传的数据从主节点复制一份到从节点,从而可以提高读性能,而这种方式并不能提升写性能,因为每一份数据都会在从节点上写一份 缺点:为了增加读写性能,数据库都是将数据 先存入内存中,随后同步到数据文件中,也就是磁盘上,两者同步是异步同步,也就是说,从节点上的数据是落后于主节点的 复制过程: 客户端写入数据---->主服务器的事务日志内存---->事物日志文件---->同步到数据文件---->通过二进制文件---从服务器的IO线程---->中继日

MySQL数据库半同步复制

半同步复制,是有一个从节点或者一部分从节点与主节点之间是同步复制的,其他的从节点仍是异步复制 半同步复制是谷歌公司贡献给MySQL的一个插件,默认在MySQL中没有此插件,所以要实现主从的版同步复制需要安装此插件 rpm -ql mariadb-server| grep semi #找到需要安装的插件,以so结尾 SHOW PLUGINS; #查看当前支持的插件,此处也能看到myisam和innodb也是插件类型 下面开始介绍如何配置主从版同步复制: 1.创建传统的主从复制功能的mysql,请参

Mysql数据库学习之mysql半同步复制简析

从5.7版本开始MySQL通过扩展的方式支持了半同步复制,当主库执行一个更新操作事务时,提交操作会被阻止直到至少有一个半同步的,复制slave确认已经接收到本次更新操作,主库的提交操作才会继续,半同步复制的slave发送确认消息只会在本次更新操作记录已经记录到本地的relay log之后,如果没有任何slave发送确认消息而导致超时时,半同步复制会转换成异步复制. 半同步复制会对MySQL性能产生影响,因为主库的提交动作只有在收到至少一个从库的确认消息之后才能执行.但这个功能是性能和数据可靠性方

MariaDB(MySQL):半同步复制+ssl+复制过滤

一.半同步复制   1.mysql的复制 通过记录主服务器的二进制日志,并在从服务器上进行重放(replay)完成复制,默认都是异步进行的. 2.半同步复制 半同步复制是google贡献给MySQL的一个补丁,在MySQL 5.5之后就支持了,MariaDB都是支持的. MySQL的插件,一般在MySQL安装目录下; 半同步复制插件默认没有启用,需要自己安装,/usr/local/mysql/lib/plugin可以看到semisync_master.so和semisync_slave.so和其

Mysql半同步复制模式说明 - 运维小结

MySQL主从复制包括异步模式.半同步模式.GTID模式以及多源复制模式,默认是异步模式 (如之前详细介绍的mysql主从复制).所谓异步模式指的是MySQL 主服务器上I/O thread 线程将二进制日志写入binlog文件之后就返回客户端结果,不会考虑二进制日志是否完整传输到从服务器以及是否完整存放到从服务器上的relay日志中,这种模式一旦主服务(器)宕机,数据就可能会发生丢失. 异步模式是一种基于偏移量的主从复制,实现原理是:主库开启binlog功能并授权从库连接主库,从库通过chan