前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql 备份详细解

mysql 备份详细解

作者头像
OwenZhang
发布2021-12-08 15:42:48
2730
发布2021-12-08 15:42:48
举报
文章被收录于专栏:Owen's World

Mysqldump

代码语言:javascript
复制
导出不含创建数据库的语
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
复制代码

全部数据库备份

代码语言:javascript
复制
//单数据库备份
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
复制代码

还原

代码语言:javascript
复制
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
复制代码

增量备份

代码语言:javascript
复制
innobackupex  --user=root --incremental-basedir=/data/backup/2015-09-18_16-35-12 --incremental /data/backup/
复制代码

查看增量备份记录文件

代码语言:javascript
复制
[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
复制代码

增量恢复

代码语言:javascript
复制
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.进行增删改查。成功。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年10月22日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档