mysql数据备份与恢复

一.备份数据的方式

1.物理备份  

   1.1冷备 cp tar等  

   1.2热备 mysqlhotcopy    只能备份存储引擎是myisam的表,依赖perl-DBD-MySQL

2.逻辑备份:用mysql自己提供的备份命令或第三放方软件提供的备份命令,备份创建库、表、和产生表记录时的sql语句。


二.数据备份策略:

1.完整备份         备份数据库服务器上的所有库所有表。

2.差异备份         备份自完整备份后所有产生的新数据。

3.增量备份         备份自上一次备份后所有产生的新数据

生产环境一般采用  完整备份+增量备份 或者 完整备份+差异备份


三.逻辑备份与恢复

1.mysqldump命令做数据的完整备份

命令格式:

mysqldump -h数据库服务器ip -u用户名 -p密码  数据库名 > 目录名/备份文件名


数据库名的表示方式:

--all-databases                     备份数据库服务器上的所有库所有表

数据库名                            对某个库做完整备份

数据库名  表                        对指定库里的指定表做完整备份

-B 数据库名1 数据库名2 数据库N      对某几个库做完整备份


#目录名 :若备份时不写目录名备份文件就存放在,执行备份命令时 所在的目录下

#备份文件名 :可以自己定义,要有标识性,约定俗成mysql的备份文件都以.sql 结尾

                      若文件重名,上一次备份会被当前备份覆盖。

# 备份用来连接数据库服务器的用户,要有被备份的目标库有相应的权限才可以。



2.恢复完整备份数据

命令格式:

mysql  -h数据库服务器ip  -u用户名   -p密码   数据库名   <  目录名/xxx.sql

mysql  -h数据库服务器ip   -u用户名  -p密码    <   目录名/xxx.sql


# 数据库名:可选项,当备份文件中有 create database,use  sql语句时,恢复数据时可以不指定数据库名。

# 用完整备份文件 恢复数据,只能把数据恢复到备份时的状态,完整备份之后产生的信息数据是无法恢复。


四.使用binlog日志做增量备份与数据恢复


1.mysql日志类型

mysql共有4种类型日志:

binlog日志(二进制日志)  记录除查询之外sql语句。

错误日志                  记录mysql服务在启动和运行过程中产生的错误。

查询日志                  记录执行的所有的sql操作。

慢查询日志                只记录超过指定时间,显示查询结果的sql语句。默认超时时间是10秒。


#默认情况下,mysql只开启错误日志。

#默认情况下日志都存放在数据库目录下。每种日志文件都默认命名方式。


2.启用binlog日志

vim /etc/my.cnf

[mysqld]

log_bin=/binlogdir/filename         //设置存放binlog目录和文件名,自定义目录必须让mysql用户有写入权限,目录不设置则默认在数据库目录/var/lib/mysql/下,文件名不设置则默认为:主机名-bin.000001                                    

max-binlog-size=100M                 //设置binlog日志文件的大小,不设置则默认为500M自动生成第二个binlog日志文件


service  mysql  restart


# 对所有库操作的使用数据发送改变的sql语句都会写进当前编号最大的binlog日志文件里。

# localhost-bin.index   记录当前已有binlog日志文件


3.分析binlog日志文件内容。

binlog日志记录sql语句的方式:

① 时间方式

② 字符偏移量方式


命令格式:

mysqlbinlog  [选项]   binlog日志文件名

选项:

偏移量

--start-position=100         起始位置

--stop-position=1200         结束位置

时间点:

--start-datetime="YYYY-mm-dd  HH:MM:SS"   起始时间

--stop-datetime="YYYY-mm-dd  HH:MM:SS"    结束时间


# 不加任何选项则默认查看全部日志内容


4.手动生成新的binlog日志文件方式:

① mysql>flush logs;

② #mysql -h数据库服务器IP -u用户名 -p密码 -e "flush logs"

③ #mysqldump -h数据库服务器IP -u用户名 -p密码 --flush-logs 数据库名> /目录名/xxx.sql

④ service  mysql  restart               //一般不用


5.增量备份数据恢复

原理:使用mysqlbinlog提取历史sql操作管道给mysql命令重做

命令格式:

mysqlbinlog   [选项]  binlog日志文件名   |  mysql  -h数据库服务器ip  -u用户名  -p密码   数据库名


批量恢复增量备份:

mysqlbinlog  `cat localhost-bin.index`| mysql -h数据库服务器ip -u用户名 -p密码  [数据库名]


6.清理binlog日志

删除早于指定编号的binlog日志文件:

mysql> PURGE  MASTER LOGS TO  'binlog日志文件名';


删除所有binlog日志文件,重建新日志:

mysql> RESET  MASTER;


五.第三方数据备份软件Xtrabackup的使用

Xtrabackup是一款强大的在线热备份工具,备份工程不锁库表


1.下载安装软件包

rpm -ivh percona-xtrabackup-2.1.6-702.rhel6.x86_64.rpm

依赖包perl-DBD-MySQL

rpm  -ql  percona-xtrabackup

/usr/bin/xtrabackup          mysql服务软件5.5以下版本

/usr/bin/xtrabackup_55       mysql服务软件版本5.5

/usr/bin/xtrabackup_56       mysql服务软件版本5.6


2.命令格式:

xtrabackup_56    <选项>

选项

--backup                           执行备份数据操作

--prepare                          准备恢复数据

--target-dir                       指定备份目录

--datadir                          指定数据库目录

--incremental-basedir              指定对哪个目录做增量备份

--incremental-dir                  指定用哪个备份目录做增量恢复


# xtrabackup  只备份表中记录,不备份表结构。所以用xtrabackup备份的文件恢复数据时库、表一定要存在。


3.Xtrabackup 完整备份与恢复

mkdir   /mysqlbak/                //创建备份目录

xtrabackup_56 --backup  --datadir=/var/lib/mysql --target-dir=/mysqlbak  //执行完整备份


xtrabackup_56 --prepare  --datadir=/var/lib/mysql   --target-dir=/mysqlbak  //完整恢复


cp  /mysqlbak/xtrabackdb/*    /var/lib/mysql/xtrabackdb/   //将要恢复的表记录拷贝回数据库下的库里,并覆盖  


service  mysql  restart                      //重启服务就可看到恢复的数据


4.Xtrabackup 增量备份与恢复

#  增量备份时,必须事先有一次完整备份,这样才知道哪些数据是新产生的数据。

mkdir   /mysqlbak

mkdir   /mysqlbak/first

xtrabackup_56  --backup --datadir=/var/lib/mysql --target-dir=/mysqlbak/first  //完整备份


mkdir   /dbbak/second


xtrabackup_56  --backup  --datadir=/var/lib/mysql  --target-dir=/mysqlbak/second   --incremental-basedir=/mysqlbak/first                              //第一次增量备份


mkdir   /dbbak/three

xtrabackup_56  --backup  --datadir=/var/lib/mysql  --target-dir=/mysqlbak/third   --incremental-basedir=/mysqlbak/second                            //第二次增量备份


增量备份数据恢复:

xtrabackup_56 --prepare --datadir=/var/lib/mysql --target-dir=/mysqlbak/first

                                       

xtrabackup_56   --prepare  --datadir=/var/lib/mysql  --target-dir=/mysqlbak/first  --incremental-dir=/mysqlbak/second


xtrabackup_56   --prepare  --datadir=/var/lib/mysql  --target-dir=/mysqlbak/first  --incremental-dir=/dbbak/third


cp /mysqlbak/first/xtrdb/*    /var/lib/mysql/xtrdb/


service  mysql  restart


你可能感兴趣的:(linux,mysql,备份,binlog,xtrabackup)