开发者社区> owenzhang> 正文

mysql 备份详细解

简介: mysql 备份详细解
+关注继续查看

小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。

Mysqldump

导出不含创建数据库的语句
mysqldump -uroot -proot wms > 1.sql
包含创建数据库的语句
mysqldump -uroot -proot --databases wms > 1.sql
//导出某张表
mysqldump -uroot -proot wms wms_goods > 1.sql
//导出binlog的位置并注释,且不锁表 single-transaction的作用是开启事务
mysqldump -uroot -proot --master-data=2 --single-transaction wms wms_goods > 1.sql

全部数据库备份

//单数据库备份
innobackupex --user=root --password=123456 --database=backup_test /data/backup/
 
//多库
innobackupex--user=root --password=123456 --include='dba.*|dbb.*' /data/backup/
 
//多表
innobackupex --user=root --password=123456 --include='dba.tablea|dbb.tableb' /data/backup/
 
//数据库备份并压缩
log=zztx01_`date +%F_%H-%M-%S`.log
db=zztx01_`date +%F_%H-%M-%S`.tar.gz
innobackupex --user=root --stream=tar /data/backup  2>/data/backup/$log | gzip 1> /data/backup/$db
//不过注意解压需要手动进行,并加入 -i 的参数,否则无法解压出所有文件,疑惑了好长时间
 
//如果有错误可以加上  --defaults-file=/etc/my.cnf

还原

service mysqld stop
mv /data/mysql /data/mysql_bak && mkdir -p /data/mysql
 
//--apply-log选项的命令是准备在一个备份上启动mysql服务
innobackupex --defaults-file=/etc/my.cnf --user=root --apply-log /data/backup/2015-09-18_16-35-12
 
//--copy-back 选项的命令从备份目录拷贝数据,索引,日志到my.cnf文件里规定的初始位置
innobackupex --defaults-file=/etc/my.cnf --user=root --copy-back /data/backup/2015-09-18_16-35-12
 
chown -R mysql.mysql /data/mysq
service mysqld start

增量备份

innobackupex  --user=root --incremental-basedir=/data/backup/2015-09-18_16-35-12 --incremental /data/backup/

查看增量备份记录文件

[root@localhost 2015-09-18_16-35-12]# cat xtrabackup_checkpoints //全备目录下的文件
backup_type = full-prepared
from_lsn = 0 //全备起始为0
to_lsn = 23853959
last_lsn = 23853959
compact = 0

增量恢复

innobackupex --apply-log --redo-only BASE-DIR
innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
其中BASE-DIR是指全备目录,INCREMENTAL-DIR-1是指第一次的增量备份,INCREMENTAL-DIR-2是指第二次的增量备份,以此类推。
这里要注意的是:最后一步的增量备份并没有--redo-only选项!还有,可以使用--use_memory提高性能。
以上语句执行成功之后,最终数据在BASE-DIR(即全备目录)下。

mysqldump的方法耗时:备份+网络传输+恢复 缺点:时间

直接复制文件的方法耗时:网络传输 缺点:可能造成意外的情况

第一种已经实践过了,今天试下第二种。

1.tar zxvf bak.tar.gz xxx xxx

把几个文件打包。文件是mysql下的datadir目录下的文件。

除去log文件。其他都需要。


2.移到新机器下

tar zxvf bak.tar.gz


3.启动mysql服务

报错:启动失败。quit without update.....


4.ps aux|grep mysql 没有存在的进程。


5.ll | awk '/mysql-bin/{print $9}' | xargs rm

把新机器的datadir目录下原本存在的一些日志文件删除


6.service mysql start

启动成功。


7.进行增删改查。成功。


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL日志管理和完全备份增量备份与恢复(二)
MySQL日志管理和完全备份增量备份与恢复(二)
25 0
[ MySQL ] 使用 MySQL Workbentch 进行MySQL数据库备份 / 还原(Part 3:备份.sql文件方式)
本文主要讲解如何用 MySQL Workbentch 进行MySQL备份和恢复数据库。 本文主要大纲为:使用Workbentch备份.sql文件的方式进行备份和还原,其中包括还原自身数据库和还原到其他目标库。
39 0
[ MySQL ] 使用Navicat进行MySQL数据库备份 / 还原(Part 2:备份.sql文件方式)
本文主要讲解如何用Navicat(Navicat Premium ,或者Navicat for mysql)进行MySQL备份和恢复数据库。 本文主要大纲为:使用Navicat备份.sql文件的方式进行备份和还原,其中包括还原自身数据库和还原到其他目标库。
96 0
[ MySQL ] 使用Navicat进行MySQL数据库备份 / 还原(Part 1:备份.nb3文件方式)
本文主要讲解如何用Navicat(Navicat Premium ,或者Navicat for mysql)进行MySQL备份和恢复数据库。 本文主要大纲为:使用Navicat备份工具方式进行备份和还原,其中包括还原自身数据库和还原到其他目标库。
87 0
【MySQL】SQL语句查询、约束、备份与恢复(二)
【MySQL】SQL语句查询、约束、备份与恢复
29 0
【MySQL】SQL语句查询、约束、备份与恢复(一)
【MySQL】SQL语句查询、约束、备份与恢复
19 0
MySQL数据库系列(七)-------日志管理、备份与恢复
MySQL 的日志默认保存位置为/usr/local/mysql/data MySQL 的日志配置文件为 /etc/my.cnf,里面有个[mysqld]项。
49 0
mysql通过复制文件实现备份
mysql通过复制文件实现备份
43 0
干货!RDS MySQL高频物理备份,看这篇就够了
MySQL的物理备份包含了全量备份、增量备份、逻辑事务日志备份。
187 0
+关注
owenzhang
I actually hate programming, but I love solving problems. Phper & Gopher. Email: owen@owenzhang.com
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
让 MySQL 原生分布式触手可及
立即下载
好的 MySQL 兼容可以做到什么程度
立即下载
云数据库RDS MySQL从入门到高阶
立即下载