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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

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 系统服务器台、一台用户做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,查看主服务器二进制日志状态

02f822560452a577638d060771d97ff1.png

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线程正常运行

692e1f17aa851c44fcdf47b8113239db.png

接下来就可以测试了

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

主服务器:

1e0ec7baa374fe2568aff9461549a76f.png

从服务器:

5b1f64fd9e4adf8b60118884c6b63122.png

主主复制

主主实际上也是互为主从,互为主从:两个节点各自都要开启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

3c309cd39f22b392a13b38b32bd446cc.png

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线程正常运行


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


本文转自    honeyorange   51CTO博客,原文链接:http://blog.51cto.com/13172732/1983889

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
30天前
|
SQL 存储 关系型数据库
MySQL的主从复制&主从同步
MySQL的主从复制&主从同步
28 0
|
4月前
|
SQL 关系型数据库 MySQL
面试官:说一下MySQL主从复制的原理?
面试官:说一下MySQL主从复制的原理?
88 0
面试官:说一下MySQL主从复制的原理?
|
4月前
|
SQL 关系型数据库 MySQL
MySQL主从复制
MySQL主从复制
|
11天前
|
负载均衡 容灾 关系型数据库
mysql主从复制
mysql主从复制
28 1
|
28天前
|
SQL 存储 运维
MySQL高可用性:主从复制和集群
MySQL高可用性:主从复制和集群
34 0
|
10天前
|
SQL 关系型数据库 MySQL
mysql主从复制
mysql主从复制
|
4月前
|
关系型数据库 MySQL Linux
Linux下搭建MySQL主从复制之一主一从架构
Linux下搭建MySQL主从复制之一主一从架构
59 0
|
1月前
|
SQL 网络协议 关系型数据库
【怒怼大厂面试官】听说你精通MySQL?来说说MySQL主从复制
面试官:MySQL主从复制了解吧?嗯嗯了解的。主要是利用了MySQL的Binary Log二进制文件。那我把二进制文件丢给从库,从库复制整个文件吗。噢噢不是的。
48 1
【怒怼大厂面试官】听说你精通MySQL?来说说MySQL主从复制
|
1月前
|
监控 负载均衡 关系型数据库
|
3月前
|
SQL 负载均衡 关系型数据库
MySQL(六)主从复制
MySQL(六)主从复制
27 0