前言:mysql
前面几篇文章为你们介绍了 MySQL 各类语句语法的用法及用户权限相关知识。本篇文章将主要讲解 MySQL 数据库数据备份与恢复相关知识,主要聚焦于逻辑备份,介绍mysqldump工具的使用以及恢复方法。sql
这里简单讲下物理备份和逻辑备份的概念: 物理备份:备份数据文件,转储数据库物理文件到某一目录。物理备份恢复速度比较快,但占用空间比较大,MySQL中能够用 xtrabackup 工具来进行物理备份。 逻辑备份:对数据库对象利用工具进行导出工做,汇总入备份文件内。逻辑备份恢复速度慢,但占用空间小,更灵活。MySQL 中经常使用的逻辑备份工具为mysqldump。shell
若想用mysqldump备份整个实例,可使用 --all-databases
或 -A
参数:数据库
mysqldump -uroot -pxxxxxx --all-databases > /tmp/all_database.sql
mysqldump -uroot -pxxxxxx -A > /tmp/all_database.sql
复制代码
有的时候咱们会遇到只须要备份某些库的需求,这个时候咱们就可使用 --databases
或 -B
参数了,该参数后面跟数据库名称,多个数据库间用空格隔开。函数
mysqldump -uroot -pxxxxxx --databases testdb1 testdb2 > /tmp/testdb.sql
mysqldump -uroot -pxxxxxx -B testdb1 testdb2 > /tmp/testdb.sql
复制代码
平时咱们也会有备份部分表的需求,好比说在表变动前作个备份,那么咱们能够这样作:工具
#只备份testdb库中的test_tb表
mysqldump -uroot -pxxxxxx testdb test_tb > /tmp/test_tb.sql
#备份多张表
mysqldump -uroot -pxxxxxx testdb tb1 tb2 tb3 > /tmp/tb.sql
复制代码
有些时候一张表的数据量很大,咱们只须要部分数据,那么该怎么办呢?这时候就可使用 --where
选项了。where后面附带须要知足的条件。例如:咱们只须要tb1表中create_time大于2019-08-01的数据,那么能够这样导出:spa
mysqldump -uroot -pxxxxxx testdb tb1 --where=" create_time >= '2019-08-01 00:00:00' " > /tmp/tb1.sql
复制代码
若是咱们想备份某个库,可是某些表数据量很大或者与业务关联不大,这个时候能够考虑排除掉这些表,一样的,选项 --ignore-table
能够完成这个功能。code
mysqldump -uroot -pxxxxxx testdb --ignore-table=testdb.tb1 > /tmp/testdb.sql
复制代码
只备份结构的话可使用 --no-data
简写为 -d
选项;只备份数据可使用 --no-create-info
简写为 -t
选项。对象
mysqldump -uroot -pxxxxxx testdb --no-data > /tmp/testdb_jiegou.sql
mysqldump -uroot -pxxxxxx testdb --no-create-info > /tmp/testdb_data.sql
复制代码
mysqldump备份默认是不包含存储过程,自定义函数及事件的。咱们可使用 --routines
或 -R
选项来备份存储过程及函数,使用 --events
或 -E
参数来备份事件。例如:咱们想备份整个testdb库,包含存储过程及事件:事件
mysqldump -uroot -pxxxxxx -R -E --databases testdb > /tmp/testdb.sql
复制代码
若是咱们想在dump过程当中保证数据的一致性,减小锁表,则能够用 --single-transaction
选项,这个选项对InnoDB的数据表颇有用,且不会锁表。
mysqldump -uroot -pxxxxxx --single-transaction --databases testdb > /tmp/testdb.sql
复制代码
若是咱们如今有昨天的全量备份,如今想整个恢复,则能够这样操做:
mysql -uroot -pxxxxxx < /tmp/all_database.sql
复制代码
可能有这样的需求,好比说咱们只想恢复某一个库,可是咱们有的是整个实例的备份,这个时候咱们想到能不能从全量备份中分离出单个库的备份,答案是能够的,下面这个简单的shell能够帮到你哦:
sed -n '/^-- Current Database: `testdb`/,/^-- Current Database: `/p' all_databases.sql > testdb.sql
#分离完成后咱们再导入testdb.sql便可恢复单个库
复制代码
这个需求仍是比较常见的,毕竟单库或全量恢复涉及的业务仍是比较多的,恢复时间也比较长,好比说咱们知道哪一个表误操做了,那么咱们就能够用单表恢复的方式来恢复。例如:如今咱们有testdb整库的备份,可是因为tb1表误操做,须要单独恢复出这张表,那么咱们能够这么作:
cat testdb.sql | sed -e '/./{H;$!d;}' -e 'x;/CREATE TABLE `tb1`/!d;q' > /tmp/tb1_jiegou.sql
cat testdb.sql | grep --ignore-case 'insert into `tb1`' > /tmp/tb1_data.sql
#用shell语法分离出建立表的语句及插入数据的语句后 再依次导出便可完成恢复
复制代码
总结:
本篇文章给出了在不一样场景下的备份及恢复方法,可能生产中还会有更复杂的场景,须要你们灵活应变。至此,『入门MySQL』系列已经完结,虽然这几篇文章写得并非那么深刻有趣,但仍是但愿你们看完后能对MySQL有个基础的认识。在这里也要感谢你们的阅读,是大家一次次的阅读让我有写下去的动力!后续我还会分享MySQL相关文章,但愿你们持续关注。