小知识,大挑战!本文正在参与“程序员必备小知识”创作活动。
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.进行增删改查。成功。