前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >闪回数据库不是“万金油”(r11笔记第73天)

闪回数据库不是“万金油”(r11笔记第73天)

作者头像
jeanron100
发布2018-03-21 14:35:44
6130
发布2018-03-21 14:35:44
举报
文章被收录于专栏:杨建荣的学习笔记

闪回数据库这个特性在很多Oracle DBA眼里就是鸡肋特性,因为谁会因为恢复数据而需要在主库闪回,最后可能丢掉更多的数据,这个观点没错。

但是如果是备库呢,这个特性就顺利成章的满足了绝大多数的恢复需求,无论你是truncate,还是一些drop table的操作都是可以轻而易举的恢复。所以更多的时候我们其实更偏爱于Data Guard基础上的这种数据恢复方式,而原本的逻辑备份exp,expdp,物理备份RMAN就显得有些臃肿了。

拿一个真实的小案例来说明,有一次因为数据查询的SQL有问题,结果查出的数据结果有问题,但是发现的时候这个时间已经过去了好几天,要追溯到那天那个时间点的数据状态,使用备份是完全不可能的。这个时候因为备库开启了闪回,我们可以很轻松的恢复到几天前的任意一个时间点,就这样这个问题就引刃而解了。这也算是闪回数据库尝到了一些甜头。所以在后来这个特性我也会逐步放开手脚去使用。

但是对于闪回数据库,很多场景虽然恢复起来全然没有问题,但是它可能不是罪完美的,如果让你说出个一二三,可能也会不是很肯定。

其实闪回数据库不是数据恢复的“万金油”,有一些场景它是无法实现闪回的。我们要清楚的这个这个边界才能在数据恢复的时候更加充满信心。这个信息还是从官方文档中能够得到要合适一些。(https://docs.oracle.com/cd/E11882_01/backup.112/e10642/flashdb.htm#BRADV286)

大体来说,有下面的几个场景是无法实现闪回的。

1.通过闪回数据库来修复介质问题或者是数据文件丢失

2.如果对数据文件做了收缩操作,比如数据文件为200M,我们收缩为190M,那么这个我们是无法闪回到收缩前的状态的。

3.如果drop datafile这样的操作,本身也是无法支持闪回的,而且在10g的子版本中,这个操作直接会导致MRP异常终止。

4.一些特殊的NOLOGGING操作是不支持闪回的,比如做一个direct path的数据导入,比如持续时间是9:00~9:15,启用了Nologging,如果你要闪回到9:07的这个状态是不可以的。

总体来看上面的几个场景,也算是极为罕见了。而且放开所有的权限,开发同学是全然没有这些权限去破坏和操作的。

我们来简单做一个例子来强化理解一下。

SQL> select file_id,file_name ,bytes/1024/1024 from dba_data_files; FILE_ID FILE_NAME BYTES/1024/1024 ---------- -------------------------------------------------- ---- 4 /home/oracle/users01.dbf 935 3 /U01/app/oracle/oradata/dataguru/undotbs01.dbf 295 2 /U01/app/oracle/oradata/dataguru/sysaux01.dbf 1250 1 /U01/app/oracle/oradata/dataguru/system01.dbf 750 5 /U01/app/oracle/oradata/dataguru/test_new01.dbf 200 6 /U01/app/oracle/oradata/dataguru/test/test02.dbf 10 我们记下一个时间戳。然后在主库端把5号文件从200M收缩到190M.

alter database datafile '/U01/app/oracle/oradata/dataguru/test_new01.dbf' resize 190M;这个时候查看数据文件的大小是明显发生了变化,收缩到了190M.

那么我们在备库端取消日志应用,准备开始闪回。

SQL> recover managed standby database cancel; Media recovery complete. SQL> alter database close; Database altered.

开始闪回数据库到收缩前的状态。

SQL> flashback database to timestamp to_timestamp('2017-02-12 22:32:15','yyyy-mm-dd hh24:mi:ss'); flashback database to timestamp to_timestamp('2017-02-12 22:32:15','yyyy-mm-dd hh24:mi:ss') * ERROR at line 1: ORA-38766: cannot flashback data file 5; file resized smaller ORA-01110: data file 5: '/U01/app/oracle/oradata/dataguru/test_new01.dbf'

由此可以看出这个操作是支持不了的,所以对于闪回数据库这些场景就是一些底线,我们需要了解闪回数据库能够做什么,哪些是不支持的。

明确了这些问题,其实闪回数据库还是大有可为。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-02-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 杨建荣的学习笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档