mysql备份

一、Mysql备份策略:

完整备份:

完整备份就是指对某一个时间点上的所有数据或应用进行的一个完整拷贝,对数据量大的,备份时间较长,当然数据在恢复的时候快。

增量备份:

备份自上一次备份(包括完整备份,差异备份,增量备份)之后所有变化的数据进行备份。恢复的时候只需要一次完整的备份加上完整备份后的多个增量备份进行恢复即可。

差异备份:

备份自上一次完整备份之后所有变化的数据,恢复的时候仅需要最新一次完整备份加上差异备份即可。

详细如下图所示:


备份方式:

1、使用mysqldump进行逻辑备份

2、使用LVM快照备份:

快照备份就是把当时的场景保存为一个不变的状态,然后对这个不变的状态进行备份。但然,在规划mysql数据库时最好将数据和日志分开放到lvm分区中。使用LVM快照备份,需要将数据放在lvm分区。


3、Xtrabackup备份:


备份原理:

       XtraBackup基于InnoDBcrash-recovery功能。它会复制innodb data file,由于不锁表,复制出来的数据是不一致的,在恢复的时候使用crash-recovery,使得数据恢复一致。InnoDB维护了一个redo log,又称为transaction log,事务日志,它包含了innodb数据的所有改动情况。

当InnoDB启动的时候,它会先去检查datafile和transaction log,并且会做二步操作:

1.Itapplies committed transaction log entries to the data files

2.itperforms an undo operation on any transactions that modified data but did notcommit.


XtraBackup在备份的时候,一页一页地复制innodb的数据,而且不锁定表,

与此同时,XtraBackup还有另外一个线程监视着transactionslog,

一旦log发生变化,就把变化过的logpages复制走。


为什么要急着复制走呢?前几章的时候就提过这个问题,

因为transactions log文件大小有限,写满之后,就会从头再开始写,

所以新数据可能会覆盖到旧的数据。

在prepare过程中,XtraBackup使用复制到的transactionslog 对备份出来的innodb data file 进行crash recovery。

用mysqldump实现备份:

首先,mysqldump是mysql的一个客户端工具,可以实现备份整个服务器、单个或部分数据库、单个或部分表、表中的某些行,存储过程,存储函数,触发器等,能自动记录备份时的二进制日志文件及相应的position值


二、详解用mysqldump实现备份恢复操作:

首先,mysqldump是mysql的一个客户端工具,可以实现备份整个服务器、单个或部分数据库、单个或部分表、表中的某些行,存储过程,存储函数,触发器等,能自动记录备份时的二进制日志文件及相应的position值

对mysqldump参数说明:

--all-databases  , -A      //导出全部数据库。

--all-tablespaces  , -Y     //导出全部表空间。

--no-tablespaces  , -y     //不导出任何表空间信息。

--add-drop-database     //每个数据库创建之前添加drop数据库语句。

--add-drop-table                 //每个数据表创建之前添加drop数据表语句。(默认为打开状态,使用--skip-add-drop-table取消选项)

--add-locks                    //在每个表导出之前增加LOCK TABLES并且之后UNLOCK  TABLE。(默认为打开状态,使用--skip-add-locks取消选项)

--allow-keywords          //允许创建是关键词的列名字。这由表名前缀于每个列名做到。

--apply-slave-statements //在'CHANGE MASTER'前添加'STOP SLAVE',并且在导出的最后添加'START SLAVE'。

--character-sets-dir        //字符集文件的目录

--comments                   //附加注释信息。默认为打开,可以用--skip-comments取消

--compatible                  //导出的数据将和其它数据库或旧版本的MySQL 相兼容。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options等,

要使用几个值,用逗号将它们隔开。它并不保证能完全兼容,而是尽量兼容。

--compact                      //导出更少的输出信息(用于调试)。去掉注释和头尾等结构。可以使用选项:--skip-add-drop-table  --skip-add-locks --skip-comments --skip-disable-keys

--complete-insert,  -c     //使用完整的insert语句(包含列名称)。这么做能提高插入效率,但是可能会受到max_allowed_packet参数的影响而导致插入失败。

--compress, -C      //在客户端和服务器之间启用压缩传递所有信息

--create-options,  -a      //在CREATE TABLE语句中包括所有MySQL特性选项。(默认为打开状态)

--databases,  -B      //导出几个数据库。参数后面所有名字参量都被看作数据库名。

--debug          //输出debug信息,用于调试。默认值为:d:t:o,/tmp/mysqldump.trace

--debug-check    //检查内存和打开文件使用说明并退出。

--debug-info       //输出调试信息并退出

--delete-master-logs           //master备份后删除日志. 这个参数将自动激活--master-data。

--disable-keys           //对于每个表,用/*!40000 ALTER TABLE tbl_name DISABLE KEYS */;和/*!40000 ALTER TABLE tbl_name ENABLE KEYS */;语句引用INSERT语句。这样可以更快地导入dump出来的文件,因为它是在插入所有行后创建索引的。该选项只适合MyISAM表,默认为打开状态。

--dump-slave //该选项将导致主的binlog位置和文件名追加到导出数据的文件中。设置为1时,将会以CHANGE MASTER命令输出到数据文件;设置为2时,在命令前增加说明信息。该选项将会打开--lock-all-tables,除非--single-transaction被指定。该选项会自动关闭--lock-tables选项。默认值为0。

--events, -E      //导出事件。

--flush-logs   //开始导出之前刷新日志。

请注意:假如一次导出多个数据库(使用选项--databases或者--all-databases),将会逐个数据库刷新日志。除使用--lock-all-tables或者--master-data外。在这种情况下,日志将会被刷新一次,相应的所以表同时被锁定。因此,如果打算同时导出和刷新日志应该使用--lock-all-tables 或者--master-data 和--flush-logs。

--flush-privileges//在导出mysql数据库之后,发出一条FLUSH  PRIVILEGES 语句。为了正确恢复,该选项应该用于导出mysql数据库和依赖mysql数据库数据的任何时候。

--ignore-table     //不导出指定表。指定忽略多个表时,需要重复多次,每次一个表。每个表必须同时指定数据库和表名。

--lock-all-tables,  -x//提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭--single-transaction 和--lock-tables 选项。

mysqldump  -uroot -p --host=localhost --all-databases --lock-all-tables

--lock-tables,  -l      //开始导出前,锁定所有表。用READ  LOCAL锁定表以允许MyISAM表并行插入。对于支持事务的表例如InnoDB和BDB,--single-transaction是一个更好的选择,因为它根本不需要锁定表。

请注意当导出多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证导出文件中的表在数据库之间的逻辑一致性。不同数据库表的导出状态可以完全不同。

--log-error     //附加警告和错误信息到给定文件

--master-data//该选项将binlog的位置和文件名追加到输出文件中。如果为1,将会输出CHANGE MASTER 命令;如果为2,输出的CHANGE  MASTER命令前添加注释信息。该选项将打开--lock-all-tables 选项,除非--single-transaction也被指定(在这种情况下,全局读锁在开始导出时获得很短的时间;其他内容参考下面的--single-transaction选项)。该选项自动关闭--lock-tables选项。

--no-create-db,  -n   //只导出数据,而不添加CREATE DATABASE 语句。

--no-create-info,  -t

只导出数据,而不添加CREATE TABLE 语句。

mysqldump  -uroot -p --host=localhost --all-databases --no-create-info

--no-data, -d       //不导出任何数据,只导出数据库表结构。

--order-by-primary  //如果存在主键,或者第一个唯一键,对每个表的记录进行排序。在导出MyISAM表到InnoDB表时有效,但会使得导出工作花费很长时间。

--quick, -q     //不缓冲查询,直接导出到标准输出。默认为打开状态,使用--skip-quick取消该选项。

--opt        //同时启用各种高级选项

--routines, -R      //导出存储过程以及自定义函数。

--single-transaction//该选项在导出数据之前提交一个BEGIN SQL语句,BEGIN 不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎,仅InnoDB。本选项和--lock-tables 选项是互斥的,因为LOCK  TABLES 会使任何挂起的事务隐含提交。要想导出大表的话,应结合使用--quick 选项。

--dump-date       //将导出时间添加到输出文件中。默认为打开状态,使用--skip-dump-date关闭选项。

--skip-opt           //禁用�Copt选项.

--socket,-S     //指定连接mysql的socket文件位置,默认路径/tmp/mysql.sock

--triggers       //导出触发器。该选项默认启用,用--skip-triggers禁用它。

--user, -u        //指定连接的用户名。

--verbose, --v           //输出多种平台信息。

--version, -V        //输出mysqldump版本信息并退出



实例详解操作时数据库以及库中的表可以自己创建,主要讲解备份的过程及其中的要点

详解一:对catidb数据库进行完全备份:

1
2
3
4
5
6
7
8
9
10
mysql>use catidb;
Databasechanged
mysql>show tables;  //使用catidb数据库查看其中的表
+------------------+
|Tables_in_catidb |
+------------------+
|tb1              |
|tb2              |
+------------------+
2rows  inset(0.00 sec)

对catidb数据库进行备份,恢复

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[root@localhost~]# mysqldump -uroot -pmypass catidb > /tmp/catidb.sql  //用这种方法对catidb数据库进行备份,在数据库恢复时有一个问题,即该catidb.sql文件中没用创建catidb数据库的语句,在恢复时所含所有表会恢复到当前默认的数据库中,相当的危险,因此需要谨慎,在恢复之前一定要先创建数据库
mysql>drop database catidb;     //备份之后将catidb数据库删除
QueryOK, 2 rows affected (0.07 sec)
mysql>create database catidb;   //在恢复之前一定要先创建数据库,数据库名字可以自己定义
QueryOK, 1 row affected (0.04 sec)
mysql>use catidb;
Databasechanged
mysql> source/tmp/catidb.sql    //进行数据恢复
mysql>show tables;        //恢复成功
+------------------+
|Tables_in_catidb |
+------------------+
|tb1              |
|tb2              |
+------------------+
2rows  inset(0.01 sec)

详解二:

利用mysqldump实现从逻辑角度完全备份mysql,配合二进制日志备份实现增量备份

仍以上面的catidb数据库为例先对catidb 数据库进行完全备份

1
2
3
4
5
6
7
8
9
10
mysql>use catidb;
Databasechanged
mysql>show tables;
+------------------+
|Tables_in_catidb |
+------------------+
|tb1              |
|tb2              |
+------------------+
2rows  inset(0.00 sec)

对catidb数据库进行完全备份

[root@localhost~]# mysqldump -uroot -pmypass --single-transaction --master-data=2 --databasescatidb > /backup/catidb_`date +%F`.sql

备份完成之后又对catidb数据库进行了新的操作

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
mysql>show tables;
+------------------+
|Tables_in_catidb |
+------------------+
|tb1              |
|tb2              |
+------------------+
2rows  inset(0.00 sec)
mysql>use catidb
Databasechanged
mysql>create table tb3 ( idint);
QueryOK, 0 rows affected (0.11 sec)
mysql>insert into tb3 values (1),(6),(9);
QueryOK, 3 rows affected (0.09 sec)
Records:3  Duplicates: 0  Warnings: 0

进行增量备份:从上一次完全备份完成后,到所有新的操作之前,那么如何查看记录的位置

开始位置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[root@localhost~]# less /backup/catidb_2013-09-07.sql
--MySQL dump 10.13  Distrib 5.5.33, forLinux (x86_64)
--
--Host: localhost    Database: catidb
--------------------------------------------------------
--Server version       5.5.33-log
/*!40101SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101SET NAMES utf8 */;
/*!40103SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103SET TIME_ZONE= '+00:00'*/;
/*!40014SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE= 'NO_AUTO_VALUE_ON_ZERO'*/;
/*!40111SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;
--
--Position to start replication or point- in-timerecovery from
--
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000004',MASTER_LOG_POS=1673;

结束位置:

1
2
3
4
5
6
7
mysql>show master status;
+------------------+----------+--------------+------------------+
|File             | Position |Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000004 |     1959 |              |                  |
+------------------+----------+--------------+------------------+
1row  inset(0.00 sec)

 

你可能感兴趣的:(mysql,数据库,备份)