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

3、 SQL slave thread(SQL从线程)处理该过程的最后一步。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的表,在主服务器上可以查看到,如果在从服务器上也可以查看到,说明数据已同步,实现成功。

主服务器:

从服务器:

主主复制

主主实际上也是互为主从,互为主从:两个节点各自都要开启binlog和relay 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线程正常运行

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

mysql数据库主文件_mysql数据库的主从复制和主主复制相关推荐

  1. mysql多源复制相同数据库名称_mysql数据库多源复制方案

    概述 由于目前生产环境的mysql数据库分布在两台服务器,若从单一主从来看,配置很简单,但是需要将两台服务器的数据库同步到一台从库上面,需要进行更多配置和注意事项.多源复制有两种方案,Binlog+P ...

  2. mysql都有哪些数据库日志_MySQL数据库之MySQL都有哪些日志?分别都代表什么

    本文主要向大家介绍了MySQL数据库之MySQL都有哪些日志?分别都代表什么 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. MySQL日志:主要包含:错误日志.查询日志.慢查询 ...

  3. 物联网 mysql数据库优化_MySQL数据库优化大全方法汇总-阿里云开发者社区

    随着数据和负载增加,MySQL数据库会日渐缓慢,性能越来越差,用户体验也随之变差,所以数据库性能优化十分紧迫,云吞铺子分享MySQL数据库优化大全: MySQL数据库优化 云吞铺子先模拟一下数据库访问 ...

  4. mysql数据库监控程序_mysql数据库监控利器lepus天兔工具安装和部署

    需要的核心包如下: 以下软件包只需要部署在监控机即可.被监控机无需部署. 1.MySQL 5.0及以上(必须,用来存储监控系统采集的数据) 2.Apache 2.2及以上 (必须,WEB服务器运行服务 ...

  5. mysql数据库语法_MySQL数据库基本语法

    SQL WHAT(SQL是什么?) Structured Query Language:结构化查询语⾔ WHY(为何要使用SQL?) 难道仅仅使用SQL Server Management Studi ...

  6. Mysql常用词汇_mysql 数据库常用单词

    说明:以下单词可能有多种含义,此文档只针对编程做解释.单词不多,熟能生巧,每日认真读读写写,效果不错.如有错误,请谅解并指出,谢谢大家! 黄金超 2017-4-7 连接MySQL数据库: mysql ...

  7. mysql删除原则_MySQL数据库的增删选查

    数据库是专门存储数据对象的容器,这里的数据对象包括表.视图.触发器.存储过程等,其中表是最基本的数据对象. 创建数据库 在 MySQL 数据库中存储数据对象之前,先要创建好数据库. 语法: creat ...

  8. mysql select表达式_MySQL数据库SELECT查询表达式解析

    数据的管理在很大一部分是在进行查找工作,而SELECT占据了很大的一部分 SELECT select_expr [,select_expr...] [ FROM table_reference WHE ...

  9. mysql数据库导出_MySQL数据库导入导出详解[转发]

    1. 概述 MySQL数据库的导入,有两种方法: 1) 先导出数据库SQL脚本,再导入: 2) 直接拷贝数据库目录和文件. 在不同操作系统或MySQL版本情况下,直接拷贝文件的方法可能会有不兼容的情况 ...

最新文章

  1. Android复制Assets目录下的文件到/data/data目录
  2. Java第十次作业--多线程
  3. 电大计算机应用基础考60,(2016年电大)电大计算机应用基础考答案.doc
  4. io和nio的缓冲_IO与NIO –中断,超时和缓冲区
  5. python interactive window_如果PySide应用程序是从IPython interactive cons运行的,上下文菜单就会消失...
  6. matlab 多径 时变 信道 冲击响应,无线信道—时变冲激响应
  7. 魔兽世界转服务器显示完成,魔兽世界怀旧服:TAQ变简单了,为什么还是出现了AFK大潮?...
  8. c# 类似于QQ表情弹出框功能的二种实现方法
  9. 夺命雷公狗---微信开发54----微信js-sdk接口开发(1)之快速入门
  10. oracle服务器客户端配置文件,服务器 oracle 客户端配置文件
  11. 手机usb计算机连接不能选择,USB调试 是灰色按钮,无法点击,现在手机无法与电脑连接。...
  12. Fiddler抓包配置
  13. 世嘉MD游戏开发【十四】:SRAM存档和读档
  14. 6个实例电路,详解雷击浪涌的防护
  15. 5G网络规划面临的挑战
  16. 关于3.3V稳压芯片
  17. 拯救期末!大四留学生发“论文机器人”,替你读文献给方向调格式,已被ACL2019收录
  18. Api 数据自动入库
  19. 什么是SystemUI
  20. Sublime Text 全程图文指引

热门文章

  1. 【Java学习之代码学习】 Prog18_分数序列问题
  2. matlab 铁路振动,基于MATLAB仿真的国产铁路移频信号分析
  3. linux bzip2 命令,Linux系统中bzip2命令的语法参数介绍
  4. 作为一名理财顾问,我为什么考RFP国际理财规划师专业能力认证
  5. 细节成就成败.品质成就未来ALOKEX带给你的不仅仅只是财富还有美好未来
  6. taobao.appstore.subscribe.get( 查询appstore应用订购关系 )
  7. Linux中ps配合Kill进程的N种方法
  8. Day814.电商系统表设计优化案例分析 -Java 性能调优实战
  9. 常见的哈希算法的总结
  10. Node.js 通过https服务器利用js调用网络摄像头