博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql replication by mysqldump & xtrabackup
阅读量:4030 次
发布时间:2019-05-24

本文共 6327 字,大约阅读时间需要 21 分钟。

不停止 MySQL 服务增加从库的两种方式

现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库。前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作。

一般在线增加从库有两种方式,一种是通过mysqldump备份主库,恢复到从库,mysqldump是逻辑备份,数据量大时,备份速度会很慢,锁表的时间也会很长。另一种是通过xtrabackup工具备份主库,恢复到从库,xtrabackup是物理备份,备份速度快,不锁表。为什么不锁表?因为自身会监控主库日志,如果有更新的数据,就会先写到一个文件中,然后再回归到备份文件中,从而保持数据一致性。

服务器信息:

  • 主库:192.168.18.212(原有)
  • 从库1:192.168.18.213(原有)
  • 从库2:192.168.18.214(新增)
  • 数据库版本:MySQL5.5
  • 存储引擎:Innodb
  • 测试库名:weibo

一、mysqldump方式

MySQL主从是基于binlog日志,所以在安装好数据库后就要开启binlog。这样好处是,一方面可以用binlog恢复数据库,另一方面可以为主从做准备。

原有主库配置参数如下:

1. 主库创建同步账号

2. 从库配置MySQL

3. 备份主库

参数说明:

  • –routines:导出存储过程和函数
  • –single_transaction:导出开始时设置事务隔离状态,并使用一致性快照开始事务,然后unlock tables;而lock-tables是锁住一张表不能写操作,直到dump完毕。
  • –master-data:默认等于1,将dump起始(change master to)binlog点和pos值写到结果中,等于2是将change master to写到结果中并注释。

4. 把备份库拷贝到从库

5. 在主库创建test_tb表,模拟数据库新增数据,weibo.sql是没有的

6. 从库导入备份库

7. 在备份文件weibo.sql查看binlog和pos值

8. 从库设置从这个日志点同步,并启动

可以看到IO和SQL线程均为YES,说明主从配置成功。

9. 从库查看weibo库里面的表

发现刚才模拟创建的test_tb表已经同步过来!

二、xtrabackup方式(推荐)

在上面配置基础上做实验,先删除掉从库配置:

此时,从库现在和新装的一样,继续前进!

1. 主库使用xtrabackup备份

生成一个以时间为命名的备份目录:2015-07-01_16-49-43

2. 把备份目录拷贝到从库上

3. 从库上把MySQL服务停掉,删除datadir目录,将备份目录重命名为datadir目录

4. 在主库创建test_tb2表,模拟数据库新增数据

5. 从备份目录中xtrabackup_info文件获取到binlog和pos位置

6. 从库设置从这个日志点同步,并启动

可以看到IO和SQL线程均为YES,说明主从配置成功。

9. 从库查看weibo库里面的表

发现刚才模拟创建的test_tb2表已经同步过来。

更多Xtrabackup使用查看博文:

转载地址:http://behbi.baihongyu.com/

你可能感兴趣的文章
flutter-实现一个下拉刷新上拉加载的列表
查看>>
android 代码实现圆角
查看>>
flutter-解析json
查看>>
android中shader的使用
查看>>
java LinkedList与ArrayList迭代器遍历和for遍历对比
查看>>
Android DataBinding使用2-Recycleview
查看>>
drat中构造方法
查看>>
JavaScript的一些基础-数据类型
查看>>
JavaScript基础知识(2)
查看>>
转载一个webview开车指南以及实际项目中的使用
查看>>
android中对于非属性动画的整理
查看>>
一个简单的TabLayout的使用
查看>>
关于let{a}=B出现的解构赋值
查看>>
ReactNative使用Redux例子
查看>>
Promise的基本使用
查看>>
android给文字加边框(修改不能居中的问题)
查看>>
coursesa课程 Python 3 programming 统计文件有多少单词
查看>>
coursesa课程 Python 3 programming 输出每一行句子的第三个单词
查看>>
coursesa课程 Python 3 programming Dictionary methods 字典的方法
查看>>
Returning a value from a function
查看>>