MySQL的备份的一些策略和方法的总结

1.一般使用的是mysqldump来进行备份,每次dump的数据是1000条,并且在这个过程中会进行锁表。

(这种方式是逻辑备份,即直接将数据库中的数据导成sql语句进行备份的过程)

主要的使用方法:

(1).不带参数的进行备份:

1 备份test数据库中的所有表数据和表结构
2 mysqldump -uroot -ppassword  test >/tmp/test.sql
3 
4 备份test数据库中的某个表数据和表结构
5 mysqldump -uroot -ppassword  test student >/tmp/test_student.sql

(2).使用-B参数进行备份:(在SQL文件中自动创建原有的数据库名和连接数据库)

1 备份test数据库中的所有表数据和表结构
2 
3 使用-B会自动的创建数据库并且使用数据库
4 
5 mysqldump -uroot -ppassword  -B test >/tmp/test.sql

(3).使用-B参数进行多个数据库的备份:

1  mysqldump --user root --password=myrootpassword -B db_test db_second db_third > db_test.sql  

(4).使用gzip进行压缩数据文件进行备份:(使用管道符将数据传给gzip然后进行压缩数据成gz的包)

1 mysqldump --user root --password=myrootpassword -B db_test db_second db_third |gzip > db_test.sql.gz  

(5).使用shell进行分库备份:

1 mysql -uroot -ppasswd  -e "show databases;" |grep -Eiv "database|information|performance"|sed -r s#^([a-zA-Z_0-9]*$)#mysql -uroot -ppasswd --events -B \1 |gzip> /opt/\1.sql.gz#g‘|bash

上面的命令是将mysql中需要的库进行了分库的备份,这种是在遇到比较多的库的时候,我们可以进行分库的备份。

分库的意义何在:

有时一个企业的数据库中会有多个库,例如(bbs,www,blog),但是出问题的时候很可能往往是一个库,那如果我们将所有库的数据保存到一个文件中去,那么将来恢复数据的时候,可能会带来很大的麻烦,所以我们一般将库进行分库备份。

有的时候我们也需要将某个库中的多个表进行分别编程,思想也是和上面的分库备份一致的。

(6).备份mysql数据库的表结构(不包含数据)

1 mysqldump -uroot -ppassword  -d  test 
2 
3 参数 -d 的作用就是备份数据库的表结构。

(7).备份mysql的数据库中的数据(不包含表结构)

1 mysqldump -uroot -ppassword  -t  test 
2 
3 参数 -t 的作用就是备份数据库的表数据(不包含表结构)。

(8).备份的时候切割binlog日志:(进行增量备份的时候可以用到)

1 mysqldump -uroot -ppassword  -t  -B -F test 
2 
3 参数 -F 的作用就是备份数据库的时候,将binlog日志进行重新刷新。

(9).备份的时候会记录指定文件的位置以及mysqlbinglog的文件名称:

1  mysqldump -uroot -ppassword  -t  -B -F --master-data test 
2  
3  参数 --master-data=1 的作用就是备份数据库的时候,将binlog日志进行重新刷新。

mysqldump的一些关键参数总结:

1、-B:表示的是指定多个库,增加了建库语句和use数据库的语句。

2、--compact:去掉注释,适合调试输出,不适合在生产环境使用。

3、-A: 表示的是本分所有的库。

4、-F:刷新binlog日志,方便进行增量的恢复。

5、--master-data:增加binlog日志文件名及其对应的位置点。

6、-x,--lock-all-tables :在备份的时候进行锁表,保持数据的一致性。

7、-d:只备份表的结构。

8、--single-transaction  适合innodb数据库的备份。

Innodb表在备份的时候,通常启用选项--single-transaction 来保证备份的一致性,实际上他的工作原理是设定本次备份的会话级别为:repeattable read ,以确保本次会话dump时,不会看到其他的会话提交了数据。

对于不同的引擎,表的备份数据:

MyISAM:

1 mysqldump -uroot -ppassword --flush-privileges -A -B --master-data=2 -x --flush-logs --triggers --routines --events --hex-blob |gzip > /opt/all.sql.gz

InnoDB:

1 mysqldump -uroot -ppassword --flush-privileges -A -B --master-data=2 --single-transaction --flush-logs --triggers --routines --events --hex-blob |gzip > /opt/all.sql.gz

推荐使用InnoDB的备份方式,备份数据。(--triggers 表示的是触发器)

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。