MySQL数据库之备份与恢复

目录

引言

一、MySQL日志管理

1、日志的类型与作用

redo 重做日志

undo 回滚日志

errorlog 错误日志

slow query log 慢查询日志

bin log 二进制日志

relay log 中继日志

general log 普通日志

2、日志的查询

二、数据备份的重要性

造成数据丢失的原因

三、备份类型

1、物理备份

2、冷备份

3、热备份

①数据文件一个表空间的备份

②备份归档log文件

③用alter database bachup controlfile命令来备份控制文件热备份的优点

④用alter database bachup controlfile命令来备份控制文件热备份的优点

⑤热备份的不足

四、备份策略

1、完全备份

优点

缺点

2、差异备份

3、增量备份

4、如何选择逻辑备份策略

合理值区间

五、常见的备份方法

1、物理冷备

2、专用备份工具mysqldump或者mysqlhotcopy

mysqldump工具

mysqlhotcopy工具

3、启动二进制日志进行增量备份

4、第三方工具备份

六、MySQL完全备份与恢复

1、物理冷备份与恢复

压缩备份 

解压恢复 

2、mysqldump备份与恢复 

完全备份有个或多个完整的库(包含其中所有的表) 

3、完全备份MySQL服务器中所有的库 

4、完全备份指定库中的部分表

5、查看备份文件

6、MySQL完全恢复

恢复数据库

恢复数据表 

7、加-databases和不加的区别 

七、MySQL增量备份与恢复

1、开启二进制日志功能

STATEMENT(基于sQL语句) 

ROW(基于行)

2、二进制日志读取

3、节点恢复 

总结

1、备份的类型

2、物理备份:冷备、温备、热备

3、逻辑备份:全量备份、增量备份、差异备份

4、日志的保存类型

5、mysql恢复的方式


引言

备份的主要目的是容灾恢复,备份还可以测试应用、回滚数据修改、查询历史数据、审计等。在备份,恢复中,日志起到了很重要的作用。

一、MySQL日志管理

MySQL的日志默认保存位置为/var/lib/

MySQL的日志配置文件在/etc/my.cnf,里面有个[mysqld]项

1、日志的类型与作用

redo 重做日志

达到事务一致性(每次重启会重做)
确保日志的持久性,防止发生故障,脏页未写入磁盘。重启数据库会进行redo log执行重做,达到事务一致性

undo 回滚日志

保证数据的原子性,记录事务发生之前的一个版本,用于回滚innodb事务可重复读和读取已提交隔离级别就是通过mvcc+undo实现

errorlog 错误日志

MySQL本身启动,停止,运行期间发生的错误信息

slow query log 慢查询日志

记录执行时间过长的sql,时间阈值(10s)可以配置,只记录执行成功,在于提醒优化

bin log 二进制日志

用于主从复制,实现主从同步,记录的内容是:数据库中执行的sql语句

relay log 中继日志

用于数据库主从同步,将主库发来的bin log保存在本地,然后从库进行回放

general log 普通日志

记录数据库的操作明细,默认关闭,开启后会降低数据库性能

2、日志的查询

#登如mysql
mysql -u root -p
 
#查看通用查询日志是否开启
show variables like 'general%';
#查看二进制日志是否开启
show variables like 'log_bin%';                                    
#查看慢查询日功能是否开启
show variables like '%slow%';                                
#查看慢查询时间设置
show variables like 'long_query_time';                        
#在数据库中设置开启慢查询的方法
set global slow_query_log=ON;

二、数据备份的重要性

备份的主要目的是灾难恢复

再生产环境中,数据的安全性至关重要

任何数据的丢失都可能产生严重的后果

造成数据丢失的原因

程序错误

人为操作错误

运算错误

磁盘故障

灾难(如火灾,地震)和盗窃

三、备份类型

1、物理备份

数据库备份可以分为物理备份和逻辑备份,物理备份是对数据操作系统的物理文件(如数据文件、日志文件等)的备份。这种类型的备份适合再出现问题的时候需要快速恢复的大型重要数据库。

物理备份又分成冷备份(脱机备份)、热备份(联机备份)和温备份。

冷备份:是在关闭数据库的时候进行的

热备份:数据处于运行状态,依赖于数据库的日志文件

温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作

2、冷备份

冷备份发生在数据库已经正常关闭的情况下,当正常关闭时会提供给我们一个完整的数据库。冷备份时将要害性文件拷贝到另外的位置的一种说法。对于备份Oracle信息而言,冷备份是最快和最安全的方法。冷备份的优点是:

是非常快速的备份方法(只需拷文件)

轻易归档(简单拷贝即可)

轻易恢复到某个时间点上(只需将文件再拷贝回去)

能与归档方法相结合,做数据库“最佳状态”的恢复。

低度维护,高度安全。

但冷备份也有如下不足:

①单独使用时,只能提供到“某一时间点上”的恢复。
②再实施备份的全过程中,数据库必须要作备份而不能作其他工作。也就是说,在冷备份过程中,数据库必须是关闭状态。
③若磁盘空间有限,只能拷贝到磁带等其他外部存储设备上,速度会很慢。
④不能按表或按用户恢复。

假如可能的话(主要看效率),应将信息备份到磁盘上,然后启动数据库(使用户可以工作)并将备份的信息拷贝到磁带上(拷贝的同时,数据库也可以工作)。冷备份中必须拷贝的文件包括:

①所有数据文件
②所有控制文件
③所有联机REDO LOG文件
④Init.ora文件(可选)

值得注重的使冷备份必须在数据库关闭的情况下进行,当数据库处于打开状态时,执行数据库文件系统备份是无效的。

下面是作冷备份的完整例子。

①关闭数据库
 sqlplus /nolog
 sql>connect /as sysdba
 sql>shutdown normal;

②用拷贝命令备份全部的时间文件、重做日志文件、控制文件、初始化参数文件
 sql>cp

③重启Oracle数据库
 sql>startup

3、热备份

热备份是在数据库运行的情况下,采用archivelog mode方式备份数据库的方法。所以,假如你有昨天夜里的一个冷备份而且又有今天的热备份文件,在发生问题时,就可以利用这些资料恢复更多的信息。热备份要求数据库在Archivelog方式下操作,并需要大量的档案空间。一旦数据库运行在archivelog状态下,就可以做备份了。

①数据文件一个表空间的备份

设置表空间为备份状态

备份表空间的数据文件

回复表空间为正常状态

②备份归档log文件

临时停止归档进程

log下那些在archive rede log目标目录中的文件

重新启动archive进程

备份归档的redo log文件

③用alter database bachup controlfile命令来备份控制文件热备份的优点

可在表空间或数据库文件级备份,备份的时间短。

备份时数据库仍可使用。

可达到秒级恢复(恢复到某一时间点上)。

可对几乎所有数据库实体做恢复

恢复是快速的,在大多数情况下爱数据库仍工作时恢复。

④用alter database bachup controlfile命令来备份控制文件热备份的优点

可在表空间或数据库文件级备份,备份的时间短。

备份时数据库仍可使用。

可达到秒级恢复(恢复到某一时间点上)。

可对几乎所有数据库实体做恢复

恢复是快速的,在大多数情况下爱数据库仍工作时恢复。

⑤热备份的不足

不能出错,否则后果严重

若热备份不成功,所得结果不可用于时间点的恢复

因难于维护,所以要非常仔细小心,不答应“以失败告终”。

四、备份策略

从数据库的备份策略角度来看,备份又可分为完全备份、差异备份和增量备份

1、完全备份

每次对数据进行完整备份,即对整个数据库、数据库结构和文件结构的备份,保存的是备份完成时刻的数据库,是差异备份与增量备份的基础完全备份的备份与恢复操作都非常简单方便,但是数据存在大量的重复并且会占用大量的磁盘空间,备份的时间也很长。

每次都进行完全备份,会导致备份文件占用空间巨大,并且有大量的重复数据,恢复时,直接使用完全备份的文件即可。

完全备份是对整个数据库、数据库结构和文件结构的备份。

保存的是备份完成时刻的数据库。

是差异备份与增量备份的基础。

相当于基石。

优点

备份与恢复操作简单方便

缺点

数据存在大量的重复
占用大量的备份空间
备份与恢复时间长

2、差异备份

备份那些自从上次完全备份之后被修改过的所有文件,备份的时间节点是从上次完整备份起,备份数据量会越来越大。恢复数据时只需要恢

评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吉吉吉吉吉吉吉吉吉吉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值