一、使用Percona Xtrabackup创建MySQL slave库

MySQL Server 版本:

  Server version: 5.7.10-log MySQL Community Server (GPL)

Percona Xtrabackup 版本:

  innobackupex version 2.4.2 Linux (x86_64) (revision id: 8e86a84)

Percona Xtrabackup 安装参见下列连接:

http://www.cnblogs.com/zhenxing/p/5416296.html

说明:

[master]:表示在master库上执行的语句

[slave]:表示在slave库上执行的语句
--执行master库的全备
[master]innobackupex --parallel=4 --compress /data/backup/full --no-timestamp

--将日志附加到备份中
[master]innobackupex --apply-log --parallel=4 /data/backup/full --no-timestamp

--创建复制用户
[master]create user 'repl'@'172.25.21.%' identified by 'repl';

--授予复制用户replication权限
[master]grant replication slave on *.* to 'repl'@'172.25.21.%';

--传输数据到slave库
[master]scp -r full root@172.25.21.22:/data/backup/
--测试是否能用主库创建的用户连接到主库
[slave]mysql -h172.25.21.11 -urepl -prepl

--查看备份数据中binary log的信息
[slave]cat /data/backup/full/xtrabackup_binlog_info
  mysql-bin.000002 66379412 --进行备份恢复操作
[slave]innobackupex --copy-back --decompress /data/backup/full

--修改恢复后的数据文件目录的权限
[slave]chown -R mysql:mysql /data/mysql_data1

--启动slave库
[slave]service mysqld start --登录到slave库执行下列语句开启同步
[slave]
change master to 
master_host='172.25.21.11',
master_user='repl',
master_password='repl',
master_port=3306,
master_log_file='mysql-bin.000002',
master_log_pos=66379412; start slave; show slave status\G;

从库级联

M1-S1-S2 架构

其中S1既作为M1的从库,同时也作为S2的主库

操作步骤

只需要将原本M1-S1架构中的S1库做同样的备份操作,将备份传输到S2从库,并执行与上面类似的操作,只需S2改变change master to 用来指定到S1的IP地址及binlog postion即可。

注意:不知是否为BUG导致,创建完成后S2从库对M1(S1)的变化只记录了DDL操作,DML操作不同步,不知是否为参数引起的问题,或由于S2从库生成后未重启导致。

使用GTID模式的replication

将M1-S1-S2中S1的同步M1的模式改为基于GTID方式

Step 1: Synchronize the servers

[master/slave]  SET @@global.read_only = ON;

Step 2: Stop both servers

[master/slave] service mysqld stop

Step 3: Restart both servers with GTIDs enabled

#vi /etc.my.cnf   --master/slave中都增加或修改下列参数
log_bin = mysql-bin.log
gtid_mode = on
log_slave_updates=
enforce_gtid_consistency =
[master/slave] service mysqld start

Step 4: Direct the slave to use the master

[slave]
change master to
master_host='172.25.21.11',
master_user='repl',
master_password='repl',
master_port=,
master_auto_position=;
[slave]START SLAVE;

Step 5: Disable read-only mode

[master]SET @@global.read_only = OFF;

Step 6:Check Replication Status

[master] show master status;
[master] show processlist; [slave] show processlist;
[slave] show slave status\G;

从库错误问题解决

--错误信息
Last_SQL_Error: Error 'Operation CREATE USER failed for 'repl'@'172.25..%'' on query. Default database: ''. Query: 'CREATE USER 'repl'@'172.25..%' IDENTIFIED WITH 'mysql_native_password' AS '*A424E797037BF97C19A2E88CF7891C5C2038C039''
--由于从库上已经存在了repl这个用户,需要首先删除这个用户在启动slave,如下操作
--执行语句 [slave]drop user 'repl'@'172.25.21.%';
[slave]stop slave;
[slave]start slave;
[slave]show slave status\G;

使用Percona Xtrabackup创建MySQL slave库的更多相关文章

  1. 如何用Percona XtraBackup进行MySQL从库的单表备份和恢复【转】

    前提 应该确定采用的是单表一个表空间,否则不支持单表的备份与恢复. 在配置文件里边的mysqld段加上 innodb_file_per_table = 1 环境说明: 主库:192.168.0.1 从 ...

  2. Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)

    原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...

  3. Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

    Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)     文章目录 [隐藏] Xtrabackup简介 Xtrabackup安装 Xtrabackup工具介绍 inno ...

  4. Percona Xtrabackup备份mysql(转)

    add by zhj:另外,参考了Xtrabackup之innobackupex备份恢复详解,我用的是Xtrabackup2.2.6版本, 可以成功备份和恢复指定的数据库. 原文:http://www ...

  5. 创建MySQL从库

    我们知道Oracle有DataGuard实时备份数据.能够做主备切换,而MySQL也有自己的一套备库方案.称之为主从复制. 搭建MySQL从库是为了实时同步主库数据,同一时候也能够分担主库的读压力.对 ...

  6. Percona XtraBackup 关于 MySQL备份还原的详细测试

    一. Percona XtraBackup 的优点. (1)无需停止数据库进行InnoDB热备: (2)增量备份MySQL: (3)流压缩传输到其它服务器: (4)在线移动表: (5)能够比较容易地创 ...

  7. Percona Xtrabackup 备份MySQL 实例(转)

    老规矩,开场白,刚开始用mysqldump,备份100G+的数据库,再加上服务器繁忙,备份速度像蜗牛似的,于是寻找更高效的备份方法.网上都说用xtrabackup比较适合备份大的数据库,而且备份效率也 ...

  8. 使用 Xtrabackup 部署 MySQL 从库

    数据库备份和恢复是数据库管理工作中非常重要的一个部分. 笔者常用的两个备份工具是mysqldump (逻辑备份)和 Xtrabackup (物理备份). 对于前者一般是用在凌晨的业务低峰期的定时任务中 ...

  9. 用Xtrabackup实现MySQL全库备份与恢复

    xtrabackup包含两个主要的工具,即xtrabackup和innobackupex,二者区别如下: (1)xtrabackup只能备份innodb和xtradb两种引擎的表,而不能备份myisa ...

随机推荐

  1. JSon数据类型&使用基础

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. class.getResource()和getResourceAsStream的用法

    转自:http://blog.csdn.net/lcj8/article/details/3502849 class.getResource()的用法 用JAVA获取文件,听似简单,但对于很多像我这样 ...

  3. eclipse创建文件package,source folder和folder区别及相互转换

    原文:http://blog.csdn.net/u014079773/article/details/66973910 https://www.cnblogs.com/shihaiming/p/735 ...

  4. C4 文件和目录:APUE 笔记

    C4: 文件和目录 本章主要讨论stat函数及其返回信息,通过修改stat结构字段,了解文件属性. struct stat结构定义如下: struct stat { __dev_t st_dev; / ...

  5. iOS中的二维数组

    首先我们知道OC中是没有二维数组的,二维数组是通过一位数组的嵌套实现的,但是别忘了我们有字面量,实际上可以和C/C++类似的简洁地创建和使用二维数组.这里总结了创建二维数组的两种方法以及数组的访问方式 ...

  6. [javascript]jquery选择器笔记

    技术文档 中文:http://jquery.cuishifeng.cn/ 英文:http://api.jquery.com/category/selectors/ 分类 基本选择器 层次选择器 过滤选 ...

  7. 英语每日阅读---4、VOA慢速英语(翻译+字幕+讲解):专家:城市发展将加剧住房危机

    英语每日阅读---4.VOA慢速英语(翻译+字幕+讲解):专家:城市发展将加剧住房危机 一.总结 一句话总结:城市化(越来越多的人会住进城市)是必然趋势,人口增长也是必然趋势,人口增长必然会加大住房危 ...

  8. HTML符号大全

      HTML特殊字符编码大全:往网页中输入特殊字符,需在html代码中加入以&开头的字母组合或以&#开头的数字.下面就是以字母或数字表示的特殊符号大全.                 ...

  9. Vue 及框架响应式系统原理

    个人bolg地址 全局概览 Vue运行内部运行机制 总览图: 初始化及挂载 在 new Vue()之后. Vue 会调用 _init 函数进行初始化,也就是这里的 init 过程,它会初始化生命周期. ...

  10. 基于哈夫曼编码的压缩解压程序(C 语言)

    这个程序是研一上学期的课程大作业.当时,跨专业的我只有一点 C 语言和数据结构基础,为此,我查阅了不少资料,再加上自己的思考和分析,实现后不断调试.测试和完善,耗时一周左右,在 2012/11/19 ...