热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

innobackupex备份文件中没有mysql库_记一次innobackupex备份恢复数据库过程

简介:以前备份都是通过mysqldump备份数据库的,由于是逻辑备份,所以采用这种备份方式数据是很安全的,跨平台、版本都很容

简介:以前备份都是通过mysqldump备份数据库的,由于是逻辑备份,所以采用这种备份方式数据是很安全的,跨平台、版本都很容易。

凡事有利必有弊,逻辑备份在你数据库比较大时,备份、恢复数据所耗费的时间也是蛮长的,所以要不断改进,可以使用物理备份。

Xtrabackup是由percona开发的一个开源软件,它是innodb热备工具ibbackup(收费的商业软件)的一个开源替代品。Xtrabackup由个部分组成:xtrabackup和innobackupex,其中xtrabackup工具用于备份innodb和 xtraDB引擎的表;而innobackupex工具用于备份myisam和innodb引擎的表。

一.工具安装

[root@danny ~]# yum -y list |grep xtrabackup

percona-xtrabackup.x86_64 2.3.-.el7 @epel

holland-xtrabackup.noarch 1.1.-.el7 epel

percona-xtrabackup-test.x86_64 2.3.-.el7 epel

[root@danny ~]# yum -y install percona-xtrabackup

二.全量备份

#全备

innobackupex --defaults-file=/etc/my.cnf --user=root --password= /data/

#该语句将拷贝数据文件(由my.cnf里的变量datadir指定)至备份目录下(/data),注意:如果不指定--defaults-file,默认值为/etc/my.cnf。

备份成功后,将在备份目录下创建一个时间戳目录(本例创建的目录为/data/--18_13--/),在该目录下存放备份文件。

#在/data目录下可看到备份目录如下

[root@danny data]# ls

--18_13--

#查看原mysql库目录和当前备份目录区别

[root@izm5edykqg8tzid352ga0iz data]# ls /var/lib/mysql.bak/

auto.cnf ibdata1 lfc_oasys mysql-bin. mysql-bin.index relay-log.info sshmall

binlog_rollback.py ib_logfile0 lfc_wm mysql-bin. mysqld-relay-bin. rollback T1

diymall ib_logfile1 master.info mysqld-relay-bin.index rollback.sql wordpress

electronicproductssh_db lfcmall mysql mysql-bin. performance_schema sdbp2

[root@izm5edykqg8tzid352ga0iz data]# ls /data/--18_13--/

backup-my.cnf ibdata1 lfcmall mysql sdbp2 wordpress xtrabackup_checkpoints

diymall ib_logfile0 lfc_oasys performance_schema sshmall xtrabackup_binlog_info xtrabackup_info

electronicproductssh_db ib_logfile1 lfc_wm rollback T1 xtrabackup_binlog_pos_innodb xtrabackup_logfile

三.备份恢复

注:恢复之前,要先关闭数据库,并且删除数据文件和日志文件(本次我直接删除mysql目录下所有文件--有备份),否则恢复时会报错。

/etc/init.d/mysqld stop

rm -rf /var/lib/mysql/*

innobackupex --defaults-files=/etc/my.cnf --user=root --password=123456 --apply-log /data/2019-02-18_13-15-45/

innobackupex --defaults-file=/etc/my.cnf --user=root --password=123456 --copy-back /data/2019-02-18_13-15-45/

从上面可以看出,恢复分为两个步骤

第1步是apply-log,为了加快速度,一般建议设置--use-memory,如:--use-memory=6G,这个步骤完成之后,目录/data/2019-02-18_13-15-45/下的备份文件已经准备就绪。

注意:准备全备文件的操作只是对备份集(/data/2019-02-18_13-15-45)本身做相关处理,所以在准备恢复前最好对备份集再次备份

第2步是copy-back,即把备份文件拷贝至原数据目录下。

注意:恢复完成后一定要检查并修改权限,如下:

chown -R mysql.mysql /var/lib/mysql

/etc/init.d/mysqld start

恢复并重启mysql后目录如下:

[root@danny data]# ls /var/lib/mysql

auto.cnf ibdata1 lfcmall mysql mysql.sock sp2p wordpress

diymall ib_logfile0 lfc_oasys mysql-bin. performance_schema sshmall xtrabackup_binlog_pos_innodb

electronicproductssh_db ib_logfile1 lfc_wm mysql-bin.index rollback T1 xtrabackup_info

四.增量备份还原

备份

1.先全量备份

innobackupex --defaults-file=/etc/my.cnf --user=root --password=5113041wsdg /data/

2.第一次增量

innobackupex --defaults-file=/etc/my.cnf --user=root --password=5113041wsdg --incremental --incremental-basedir=/data/2019-02-19_09-48-41/ /data/

3.第二次增量

innobackupex --defaults-file=/etc/my.cnf --user=root --password=5113041wsdg --incremental --incremental-basedir=/data/2019-02-19_09-53-55/ /data/

备份目录如下

[root@danny data]# ls

--19_09-- //全量备份

--19_09-- //第一次增量

--19_09-- //第二次增量

还原

1.停止mysql服务器并清空数据目录

/etc/init.d/mysqld stop

mv /var/lib/mysql /tmp/

2.prepare全备

innobackupex --incremental --apply-log --redo-only /data/2019-02-19_09-48-41

3.prepare第一个增量

innobackupex --incremental --apply-log --redo-only /data/2019-02-19_09-48-41 --incremental-dir=/data/--19_09--

4.prepare第二个增量

innobackupex --incremental --apply-log /data/2019-02-19_09-48-41 --incremental-dir=/data/--19_09-- //注意最后一个增量没有--redo-only参数

此时两次增量备份其实都合并到全备上了,恢复是只需要使用全备进行恢复就可以了

5.所有整合数据还原

innobackupex --defaults-file=/etc/my.cnf --copy-back /data/--19_09--

6.修改mysql数据目录权限启动服务

chown -R mysql.mysql /var/lib/mysql

/etc/init.d/mysqld start

7.数据验证

注意:

1.通过上面三个备份目录里的xtrabackup_checkpoints文件(2019-02-19_09-53-55/xtrabackup_checkpoints),可以看出是哪种备份类型,全量(full-backuped)还是增量(incremental) 并且全量到增量的from_lsn和last_lsn是一一对应的。

2.--incremental指明是增量备份,--incremental-basedir指定上次完整备份或者增量备份文件的位置。这里的增量备份其实只针对的是InnoDB,对于MyISAM来说,还是完整备份。

Jira 的 数据库备份恢复 简单过程

1 发现jira的备份恢复很简单, 只需要导入导出一个zip包即可 导出 选择系统 管理员入口登录 选择导入导出 进行备份系统数据 选择一个文件名就能备份 备份结果 将文件copy到上一一级目录的 i ...

使用innobackupex备份mysql数据库

1  因为使用perl脚本编写,安装前应先安装 yum install perl-Time-HiRes -y yum -y install perl-DBD-MySQL.x86_64 一起安装     ...

Xtrabackup之innobackupex备份恢复详解(转)

add by zhj:对于Xtrabackup2.2来说,已经解决了本文结尾提到的那个bug,当使用--copy-back时,同时加--force-non-empty-directories 即可.这 ...

Mysql启停以及恢复备份恢复数据库

1.mysql启停 进入cmd 输入如下命令 net stop mysql(自己起的mysql名称) -------停 net strat mysql   ---------------------- ...

mysql备份恢复数据库据/表

备份单个数据库,只备份表,如要恢复,必须先创建一个数据库[root@s]# mysqldump -u root -p dbname1 > dbname1.sql[root@s]# mysql - ...

Oracle备份恢复简单过程以及中间的坑.

Oracle 冷备: 貌似需要dbca创建一致的oracle instance 服务器配置版本尽量相同,安装路径相同. 关闭Oracle服务 将oracle app 目录下的oradata以及有快速闪 ...

利用exp/imp备份恢复数据库实例

用exp/imp备份数据库: Oracle数据导入导出imp/exp功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份. 大多情况都可以用Oracle数据导入导出完成数据的 ...

Oracle之RMAN备份恢复1-基础篇

1,rman的作用与体系架构 1.1 什么是rman rman(recovery manager)是oracle8i以后dba的一重要工具一般位于$oracle_home/bin目录下,主要用来备份, ...

controlfile与备份恢复

controlfile与备份恢复     数据库正常关闭,trace controlfile信息.   ************************************************ ...

随机推荐

Tkinter单选框及滚动条

界面:左侧是单选框,右侧是信息显示框,下方是按扭 功能:点击开始爬取按扭,则会自动执行函数,显示在文本框中 indicatoron = 0 改变单选框按扭样式 效果图一: 效果图二: 效果图三: 示例 ...

最简单的视音频播放示例3:Direct3D播放YUV,RGB(通过Surface)

上一篇文章记录了GDI播放视频的技术.打算接下来写两篇文章记录Direct3D(简称D3D)播放视频的技术.Direct3D应该Windows下最常用的播放视频的技术.实际上视频播放只是Direct3 ...

机器学习算法-K-means聚类

引文: k均值算法是一种聚类算法.所谓聚类.他是一种无监督学习,将类似的对象归到同一个蔟中.蔟内的对象越类似,聚类的效果越好. 聚类和分类最大的不同在于.分类的目标事先已知.而聚类则不一样. 由于其产 ...

syslinux 3.84 2009-12-18 ebios copyright (c) 1994-2009 H. Peter Anvin et al

使用USB方式安装win7+Ubuntu12.04双系统时出现"syslinux 3.84 2009-12-18 ebios copyright (c) 1994-2009 H. Peter ...

CvvImage类

从OpenCV 2.2.0开始,OpenCV取消了CvvImage这个类.可是今天要用到,可以自己加入到工程中. 首先,找到CvvImage的原代码.我在网上已经找到了,具体代码如下. 这是CvvIm ...

【shell脚本练习】网卡信息和简单日志分析

题目 1.写一个脚本getinterface.sh,脚本可以接受参数(i,I,a),完成以下任务: (1)使用以下形式:getinterface.sh [-i interface|-I IP|-a] ...

python---购物车

购物车功能如下: 1. 输入收入多少,购买商品 2. 打印购物清单,根据清单选择商品: 3. 结算,打印购物清单及总金额 # -*- coding:utf-8 -*- # LC goods=[[1,' ...

C C++互相调用注意

注意:直接调用会找不到函数定义 1. C 调用 C++封装好后的函数: 在C++中有一个函数 int main_cpp(): 首先构建头文件, #ifndef CPP_FILE_H   #define ...

Windows共享设置

Windows文件共享默认是开启的,任何用户都可以方便的设置共享目录.那么如何关闭并禁止呢. ====打开或关闭网上邻居的网络发现:1. 右键单击,网上邻居,弹出菜单选择:属性,打开网络和共享中心界面 ...

Javascript DOM操作浅谈

1.理解DOM: DOM(Document Object Model ,文档对象模型)一种独立于语言,用于操作xml,html文档的应用编程接口. 怎么说,我从两个角度理解: 对于Javascript ...



推荐阅读
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • Ansibleplaybook roles安装redis实例(学习笔记二十九)
    1、相关redis参数:2、templatesredis.conf配置相关参数:daemonizeyespidfilevarrunredis_{{red ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 本文介绍了PhysioNet网站提供的生理信号处理工具箱WFDB Toolbox for Matlab的安装和使用方法。通过下载并添加到Matlab路径中或直接在Matlab中输入相关内容,即可完成安装。该工具箱提供了一系列函数,可以方便地处理生理信号数据。详细的安装和使用方法可以参考本文内容。 ... [详细]
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
  • PatchODAX8: ... [详细]
  • 颜色迁移(reinhard VS welsh)
    不要谈什么天分,运气,你需要的是一个截稿日,以及一个不交稿就能打爆你狗头的人,然后你就会被自己的才华吓到。------ ... [详细]
  • 1.官网下载了mysql-5.7.17-win64.zip包,配置遇到很多麻烦,记录一下;2.解压后放到指定的文件夹,修改mysql-5.7.17的配置文件my-default.i ... [详细]
  • Django + Ansible 主机管理(有源码)
    本文给大家介绍如何利用DjangoAnsible进行Web项目管理。Django介绍一个可以使Web开发工作愉快并且高效的Web开发框架,能够以最小的代价构建和维护高 ... [详细]
  • 无法打开install.wim怎么办
    运维|windows运维install.wim运维-windows运维空间留言网站源码,vscode标准代码,adamsubuntu,tomcat连接共享,sqlite软件基本操作 ... [详细]
  • wordpress 一键搭建属于自己的网站
    搭建网站很难,wordpr ... [详细]
  • 有关phpfgetss()函数的文章推荐10篇
    有关phpfgetss()函数的文章推荐10篇:了解如何使用PHP的各种文件函数。查看诸如fopen、fclose和feof之类的基本文件函数;了解诸如fgets、fgetss和f ... [详细]
  • Php怎么编写乘法表
    后端开发|PHP问题php,乘法表后端开发-PHP问题传世登陆器源码,vscode设置字号,ubuntu系统创建不了文件,tomcat配置修改,sqlite怎么调中文,海洋采集插件 ... [详细]
  • PHP操作MySql数据库_PHP教程:链接数据库$conn@mysql_connect(localhost,root,88888888)ordie(链接错误);解决中文乱码mys ... [详细]
  • php实现文件下载代码一例,
    php教程|php手册php,实现,文件下载,代码,一例,php,实现,文件下载,代码,一例,我们,需要,用到,header,函数,来,发送,php教程-php手册php实现文件下 ... [详细]
author-avatar
lin悟_462
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有