mysql数据库的主从复制和主主复制

Posted

tags:

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

mysql主从架构技术说明

Mysql内建的复制功能是构建大型,高性能应用程序的基础。将Mysql的数据分布到多个系统上去,这种分布的机制,是通过将Mysql的某一台主机(Master)的数据复制到其它主机(slaves)上,并重新执行一遍来实现的。复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,这些日志可以记录发送到从服务器的更新。当一个从服务器连接主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知新的更新。

数据库复制特性

MySQL复制技术有以下一些特点:

(1) 数据分布 (Datadistribution )

(2) 负载平衡(load balancing)

(3) 备份(Backups)

(4) 高可用性和容错性 Highavailability and failover

Mysql复制如何工作

1、该过程的第一部分就是master记录二进制日志。在每个事务更新数据完成之前,master在二进制日志记录这些改变。MySQL将事务串行的写入二进制日志,在事件写入二进制日志完成后,master通知存储引擎提交事务。此后可接收slave的请求

2、下一步就是slavemasterbinary log拷贝到它自己的中继日志。首先,slave开始一个工作线程——I/O线程。I/O线程在master上打开一个普通的连接,然后开始在主节点上binlog dump process(二进制转存线程)。Binlog dump processmaster的二进制日志中读取事件,如果已经跟上master,它会睡眠并等待master产生新的事件。I/O线程将这些事件写入中继日志。

3 SQL slave threadSQL从线程)处理该过程的最后一步。SQL线程从中继日志读取事件,并重放其中的事件而更新slave的数据,使其与master中的数据一致。只要该线程与I/O线程保持一致,中继日志通常会位于OS的缓存中,所以中继日志的开销很小。


主从复制实验


实验环境:

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

Mysql主服务器:192.168.182.173

mysql从服务器: 192.168.182.174

实验步骤:

一:配置主服务器

1.修改配置文件

vim /etc/my.cnf

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

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

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


2.查看主服务器状态

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

技术分享图片

3.创建复制帐号

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

grant replication slave on *.* to ‘slave‘@‘192.168.182.174‘identified by ‘magedu‘;


二:配置从服务器

1.修改配置文件

vim /etc/my.cnf

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

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

read_only = 1 #设置只读权限

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

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

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

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

CHANGE MASTER TO MASTER_HOST=‘192.168.222.128‘,

MASTER_USER=‘slave‘,

MASTER_PASSWORD=‘magedu‘,

MASTER_LOG_FILE=‘mysql-bin.000001‘,

MASTER_LOG_POS=245;

执行start slave# 启动复制线程。

3.查看从服务器状态

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

Slave_IO_Running: Yes #IO线程正常运行

Slave_SQL_Running: Yes #SQL线程正常运行

技术分享图片

接下来就可以测试了

在主服务器上创建一个名为xiaomi的表,在主服务器上可以查看到,如果在从服务器上也可以查看到,说明数据已同步,实现成功。

主服务器:

技术分享图片

从服务器:

技术分享图片

主主复制

主主实际上也是互为主从,互为主从:两个节点各自都要开启binlogrelay log

1、数据不一致;

2、自动增长id

定义一个节点使用奇数id

auto_increment_increment=2#表示自增长字段每次递增的量

auto_increment_offset=1#表示自增长字段从那个数开始

另一个节点使用偶数id

auto_increment_increment=2

auto_increment_offset=2


实验:主主复制

在上面主从实验的基础上,实现主主复制。

主服务器:192.168.182.174

从服务器:192.168.136.173

一:配置主服务器

vim /etc/my.cnf

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

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

relay_log=mysql-relay-log

auto_increment_increment=2
auto_increment_increment=2

技术分享图片

2.查看主服务器状态

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

3.创建复制帐号

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

grant replication slave on *.* to ‘slave‘@‘192.168.182.174‘identified by ‘magedu‘;


二:修改从服务器配置文件

1.vim /etc/my.cnf

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

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

relay_log=mysql-relay-log

auto_increment_increment=2
auto_increment_increment=2

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

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

CHANGE MASTER TO MASTER_HOST=‘192.168.182.174‘,

MASTER_USER=‘slave1‘,

MASTER_PASSWORD=‘magedu1‘,

MASTER_LOG_FILE=‘mysql-bin.000001‘,

MASTER_LOG_POS=245;

执行start slave# 启动复制线程。

3.查看从服务器状态

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

Slave_IO_Running: Yes #IO线程正常运行

Slave_SQL_Running: Yes #SQL线程正常运行


测试:无论在哪个服务器的数据库中创建数据,另一个都可以同步数据。




本文出自 “13162732” 博客,请务必保留此出处http://13172732.blog.51cto.com/13162732/1983889

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

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

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

mysql主从复制和主主复制

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

MYSQL(主从和主主配置)

主从复制及主主复制的实现