数据库备份和恢复是数据库管理工作中非常重要的一个部分。

笔者常用的两个备份工具是mysqldump (逻辑备份)和 Xtrabackup (物理备份)。

对于前者一般是用在凌晨的业务低峰期的定时任务中对数据库进行全备份;这样做的好处是导出的数据是全SQL 文本,通过管道GZIP 压缩后能够大大的节省磁盘空间(当然备份一般会上传异地服务器存储)。mysqldumpd 缺点是比较耗费时间,笔者建议数据量在50GB以内的可以使用该工具,耗时尚可接受;但是数据量超过70GB时,不建议使用该工具。

对于后者使用不太频繁,该工具也可以生成一致性备份,用于搭建主从环境。针对数据量较大的(100GB以上,甚至数百GB)数据库,备份时间上Xtrabackup的优势非常明显,并且不会影响线上业务。

下面以搭建主从环境为例,简单介绍 下 Xtrabackup  的安装和使用。演示版本为  percona-xtrabackup-2.1.9 ,支持 MySQL 5.5 5.6。

1.安装依赖软件包

yum -y install perl perl-devel libaio libaio-devel perl-DBI perl-DBD-MySQL perl-TermReadKey  perl-Time-HiRes

2.安装xtrabackup
解压tar包到安装目录,
tar -zxvf percona-xtrabackup-2.1.9-744-Linux-x86_64.tar.gz  -C  /usr/local/

重命名目录

cd /usr/local/
mv percona-xtrabackup-2.1.9-744-Linux-x86_64  xtrabackup

3.执行备份之前,先配置环境变量,否则报错

export PATH=$PATH:/usr/local/xtrabackup/bin

其中配置文件的路径和密码请根据自己的实际环境设置

备份数据文件

/usr/local/xtrabackup/bin/innobackupex --defaults-file=/usr/local/mysql/my.cnf --user=root --password=A2sW13  /ptbak/

将binlog 应用到数据文件,这是恢复数据前必须完成的步骤

/usr/local/xtrabackup/bin/innobackupex --defaults-file=/usr/local/mysql/my.cnf --user=root --password=A2sW13 --apply-log /ptbak/2016-08-09_03-49-02/

拷贝备份数据到目标数据库

scp -r  /ptbak/  192.168.80.12:/root/

3.恢复数据钱准备工作
先在目标库上停掉mysql进程
service mysqld stop

备份或者删原数据目录 (以 /usr/local/mysql/data 为示例)
mv /usr/local/mysql/data/ /usr/local/mysql/data.bak/

或者 rm -rf  /usr/local/mysql/data

(删除数据之前请三思,线上环境不建议这么干)

建立新的数据目录

mkdir -p  /usr/local/mysql/data

4.恢复数据,--copy-back 选项的作用是从备份目录拷贝数据,日志到my.cnf文件里规定的目录下
/usr/local/xtrabackup/bin/innobackupex --defaults-file=/etc/my.cnf --user=root --copy-back /root/2016-08-09_03-49-02/

修改数据目录权限
chown -R mysql:mysql  /usr/local/mysql/data

5.删除ib_logfile文件,否则mysql启动报错

cd  /usr/local/mysql/data
rm -rf ib_logfile*

启动mysql
service mysql start

6.目标数据库启动后,将拥有和源数据库相同的root密码;建议修改root密码
SET PASSWORD FOR 'root'@'localhost' = PASSWORD('xxxxxx');

7.查看备份的一致性信息
cat /root/2016-08-09_03-49-02/xtrabackup_binlog_info
mysql-bin.000969 307486338

master_log_file='mysql-bin.000969',
master_log_pos=307486338;

8.设置启用主从复制

主库上建立复制用户和权限

GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.80.12' identified by '123456';

在从库上启动复制进程
change master to
master_host='192.168.80.11',
master_port=3306,
master_user='rpel',
master_password='123456',
master_log_file='mysql-bin.000969',
master_log_pos=307486338;

>start slave;

不妥之处,敬请指教!

使用 Xtrabackup 部署 MySQL 从库的更多相关文章

  1. 使用Percona Xtrabackup创建MySQL slave库

    一.使用Percona Xtrabackup创建MySQL slave库 MySQL Server 版本: Server version: 5.7.10-log MySQL Community Ser ...

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

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

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

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

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

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

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

    Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份) Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对I ...

  6. 在 CentOS7 上部署 MySQL 主从

    在 CentOS7 上部署 MySQL 主从 通过 SecureCRT 连接至 MySQL 主服务器: 找到 my.cnf 文件所在的目录: mysql --help | grep my.cnf 一般 ...

  7. 2.快速部署MySQL主从复制

      1.快速部署MySQL主从复制 [root@mysql ~]# mysql -uroot -p123456 -S /data/3307/mysql.sock -e "show slave ...

  8. 教你手工mysql拆库

    互联网网站应用大多采用mysql作为DB存储,限于mysql单机性能的瓶颈,为了支撑更大容量和更大的访问量,dba一般通过建立分布式集群,让多个mysql共同提供服务.所谓的mysql分布式集群,实质 ...

  9. 使用 xtrabackup 进行MySQL数据库物理备份

    0. xtrabackup的功能 能实现的功能: 非阻塞备份innodb等事务引擎数据库. 备份myisam表会阻塞(需要锁). 支持全备.增量备份.压缩备份. 快速增量备份(xtradb,原理类似于 ...

随机推荐

  1. JQ倒计时,正计时

    <p class="lastP">距离二维码过期还剩<strong></strong>秒,过期后自动刷新页面.</p><scr ...

  2. servlet(5) HttpSession

    Servlet 提供的 HttpSession 接口,提供了一种跨多个页面请求或访问网站时识别用户以及存储有关用户信息的方式. Servlet 容器使用这个接口来创建一个 HTTP 客户端和 HTTP ...

  3. 洛谷P3469[POI2008]BLO-Blockade

    题目 割点模板题. 可以将图中的所有点分成两部分,一部分是去掉之后不影响图的连通性的点,一部分是去掉之后影响连通性的点,称其为割点. 然后分两种情况讨论,如果该点不是割点,则最终结果直接加上2*(n- ...

  4. python学习日记(继承和多态)

    继承 在OOP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类.父类或超类(Base class.S ...

  5. Python爬虫之三

    1)使用Scrapy,什么叫做Scrapy Scrapy,Python开发的一个快速.高层次的屏幕抓取和web抓取框架,用于抓取web站点并从页面中提取结构化的数据.Scrapy用途广泛,可以用于数据 ...

  6. 课下作业MyCP的分析

    目录 MyCP 题目 截图 代码 相关知识 出现的问题 代码托管 参考资料 MyCP 题目 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两个参数: ja ...

  7. java中53个关键字的意义及使用方法

    摘自:https://www.cnblogs.com/feng9exe/p/9224450.html 1.java的关键字分别是什么,作用是什么? static 例子: public class Te ...

  8. rocketmq 集群环境搭建配置

    rocketmq环境搭建配置: 一.   搭建三主集群,环境:centos-64 7.4 + RocketMQ-4.3.2 Master01: 192.168.102.68 Master02: 192 ...

  9. java8 日期时间解析与转换

    Instant now = Instant.now(); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM ...

  10. Linux基础知识梳理

    Linux基础知识梳理 Linux内核最初只是由芬兰人林纳斯?托瓦兹(Linus Torvalds)在赫尔辛基大学上学时出于个人爱好而编写的.Linux是一套免费使用和自由传播的类Unix操作系统,是 ...