DBA容灾与备份恢复:闪回应用及实践(一)
闪回应用及实践
针对主机故障、网络故障、系统软件故障、存储介质故障、人为操作失误等各类故障,可以通过RAC、RMAN、Data Guard等成熟的解决方案来处理,不过对于人为操作失误防范的首推技术还是使用闪回。
闪回大体有一下内容:闪回查询(Flashback Query)、闪回版本查询(Flashback Version Query)、闪回事务查询(Flashback Transcation Query)、闪回表(Flashback Table)都基于UNDO的保留信息;闪回删除(Flashback Drop)基于RECYCLE回收站机制;闪回数据库(Flashback Database)基于闪回日志;
11g的版本还多了闪回数据归档的功能,后台进程FBDA可将UNDO的信息归档,对特定表开启,起到长期历史数据追溯的作用。还支持在主库open状态下开启/关闭闪回数据库的功能,无需重启mount
第一天:
以时间戳方式恢复被勿删更新数据:
1.查看UNDO的空间是否充足
SELECT SUM(bytes / 1024 / 1024/1024) "undo sizeG"
FROM dba_data_files WHERE tablespace_name = 'UNDOTBS1';
Undo空间是Oracle数据库中用于管理事务回滚和恢复的一种机制。当事务对数据库中的数据进行修改时,Oracle会在Undo空间中为该事务分配一个Undo段,这个Undo段用于存储事务中的DML语句的Undo信息,也就是数据在被修改之前的值。
在Rollback或实例恢复(前滚)过程中,Oracle会使用Undo信息来撤销或重做事务中的操作。另外,在一致性读CR块的构造过程中,Undo信息也会被使用。由于Undo的引入,Oracle的Select语句在实现一致性读时,不需要任何锁。
需要注意的是,如果使用自动管理模式,Oracle会使用Undo表空间来管理Undo数据。如果使用手动管理模式,Oracle则会使用回滚段来管理Undo数据。在自动管理模式下,如果没有配置初始化参数UNDO_TABLESPACE,Oracle会自动选择第一个可用的Undo表空间存放Undo数据。如果没有可用的Undo表空间,Oracle会使用SYSTEM回滚段存放Undo记录,并在ALTER文件中记载警告。
2.询问操作发生时间,比如是23:48:48,经确认这个表中数据变化很小。如果能把这个时间点前的表中数据恢复出来,就能把问题的影响降到最低。
先尝试使用闪回查询来做,依赖一些缓存空间和系统的负载,在反复确认时间后,写了如下的语句:
create table tmp_xxxxx as select * from owner_account.xxxxx as of timestamp to_timestamp('20140723234845','yyyymmddHH24misss');
总结:1.在脚本提交之前,如果是DML语句,最好能够评估修改的影响范围。
2.如果脚本比较大,有性能方面的潜在因素,尽量让DBA来把关。
3.充分的测试也很重要,保证数据的安全和高可用性是很有必要的。
第二天:
使用FlashbackQuery巧妙抽取指定数据
定义:FlashbackQuery是ORACLE数据库的一项特性,它允许从回滚段中读取表在一定时间内操作过的数据,实现数据比对或者修正由于意外提交造成的错误数据。(简单的说是以时间戳的方式从指定表内抽取,若存在多个表的映射依赖关系,以映射id等条件抽取)
比如有customer和subscriber两张表的映射id是customer_id分别抽取语句如下:
select * from customer as of timestamp xxxxx where customer_id=100;
select * from subscriber as of timestamp xxxxx where customer_id=100;
xxxxx代表抽取的时间戳。
将抽取的数据保存,生成dump文件,使用exp/expdp导出dump。
create table customer nologging as select * from customer as of timestamp xxxxx where customer_id=100;
create table subscriber nologging as select * from subscriber as of timestamp xxxxx where customer_id=100;
使用exp导出dump文件:
exp username/password@service_name file=dump_file.dmp log=dump_log.log feedback=10000 buffer=104857600 statistics=none owner=schema_name
其中,username和password是连接到数据库的用户名和密码;service_name是数据库服务名称;dump_file.dmp是要生成的dump文件名;dump_log.log是日志文件名;feedback指定每处理多少行给出一次反馈;buffer指定缓冲区大小;statistics指定是否收集统计信息;owner指定要导出的模式名称。
使用expdp导出dump文件:expdp username/password@service_name DIRECTORY=dir_name DUMPFILE=dump_file.dmp LOGFILE=dump_log.log FEEDBACK=10000 BUFFER=104857600 STATISTICS=NONE SCHEMAS=schema_name
其中,username和password是连接到数据库的用户名和密码;service_name是数据库服务名称;dir_name是目录对象名称,用于指定导出文件的存储位置;dump_file.dmp是要生成的dump文件名;dump_log.log是日志文件名;feedback指定每处理多少行给出一次反馈;buffer指定缓冲区大小;statistics指定是否收集统计信息;schemas指定要导出的模式名称。
请注意,上述示例中的参数值需要根据实际情况进行替换,如用户名、密码、服务名称、文件名等。另外,导出dump文件可能需要相应的权限和准备工作,请确保在导出之前进行相应的设置和备份。
第三天:
以下是文心一言AI大模型给出解释:
- 闪回查询(Flashback Query): 这是Oracle数据库中的一种查询,允许用户查看表在过去的某个时间点的状态。例如,你可以查询一个表在过去某个时间点的数据,当你希望了解数据在过去的某个时间点的状态时,这个功能非常有用。
SELECT * FROM table_name AS OF TIMESTAMP TO_TIMESTAMP('2023-07-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS'); - 闪回版本查询(Flashback Version Query): 这种查询允许用户查看一个表在过去某个时间点的特定版本。这对于查看一个表在过去某个时间点的特定更改非常有用。
SELECT versions_xid, versions_operation, versions_startscn, my_table.*
FROM my_table
VERSIONS BETWEEN SCN MINVALUE AND MAXVALUE; - 闪回事务查询(Flashback Transaction Query): 这种查询允许用户查看一个事务在过去某个时间点的状态。这对于理解事务的历史和变化非常有用。
SELECT * FROM flashback_transaction_query WHERE xid = '030015002AFD7600E05399020000021E';
- 闪回表(Flashback Table): 这是Oracle数据库中的一个功能,允许用户将一个表回滚到过去某个时间点的状态。这对于撤销表的更改或恢复误删除的数据非常有用。
FLASHBACK TABLE my_table TO TIMESTAMP TO_TIMESTAMP('2023-07-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS'); - 闪回删除(Flashback Drop): 这是Oracle数据库中的一个功能,允许用户恢复被删除的表。这是基于RECYCLE回收站机制的。当一个表被删除时,它实际上被移动到了回收站,可以使用闪回删除来恢复它。
FLASHBACK TABLE my_table TO BEFORE DROP;
- 闪回数据库(Flashback Database): 这是Oracle数据库中的一个功能,允许用户将一个数据库回滚到过去某个时间点的状态。这是基于闪回日志的,闪回日志记录了数据库的所有更改。这对于在灾难恢复情况下恢复数据库非常有用。
STARTUP MOUNT;
FLASHBACK DATABASE TO TIMESTAMP TO_TIMESTAMP('2023-07-01 10:00:00', 'YYYY-MM-DD HH24:MI:SS');
ALTER DATABASE OPEN RESETLOGS;
摘自:杨建荣《OracleDBA工作笔记:运维、数据迁移与性能调优》及文心一言AI
DBA容灾与备份恢复:闪回应用及实践(一)的更多相关文章
- HBase 学习之路(九)——HBase容灾与备份
一.前言 本文主要介绍Hbase常用的三种简单的容灾备份方案,即CopyTable.Export/Import.Snapshot.分别介绍如下: 二.CopyTable 2.1 简介 CopyTabl ...
- HBase 系列(九)——HBase 容灾与备份
一.前言 本文主要介绍 Hbase 常用的三种简单的容灾备份方案,即CopyTable.Export/Import.Snapshot.分别介绍如下: 二.CopyTable 2.1 简介 CopyTa ...
- 入门大数据---Hbase容灾与备份
一.前言 本文主要介绍 Hbase 常用的三种简单的容灾备份方案,即CopyTable.Export/Import.Snapshot.分别介绍如下: 二.CopyTable 2.1 简介 CopyTa ...
- (4.4)mysql备份还原——备份存储容灾基础知识
存储知识 1.为什么需要存储,存储一般解决哪些问题? 容量.速度.易于管理.安全(容灾与备份).可扩展性 2.存储发展历史 [2.1]大型机 [2.2]c/s结构(客户端->服务器) [2.3] ...
- 华为云计算IE面试笔记-请描述华为容灾解决方案全景图,并解释双活数据中心需要从哪些角度着手考虑双活设计
容灾全景图: 按照距离划分:分为本地容灾 同城容灾 异地容灾 本地容灾包括本地高可用和本地主备.(本数据中心的两机房.机柜) 本地高可用这个方案为了保持业务的连续性,从两个层面来考虑: ①一个是从主 ...
- vivo 推送系统的容灾建设与实践
作者:vivo 互联网服务器团队 - Yu Quan 本文介绍了推送系统容灾建设和关键技术方案,以及实践过程中的思考与挑战. 一.推送系统介绍 vivo推送平台是vivo公司向开发者提供的消息推送服务 ...
- 删库到跑路?还得看这篇Redis数据库持久化与企业容灾备份恢复实战指南
本章目录 0x00 数据持久化 1.RDB 方式 2.AOF 方式 如何抉择 RDB OR AOF? 0x01 备份容灾 一.备份 1.手动备份redis数据库 2.迁移Redis指定db-数据库 3 ...
- 容灾恢复 | 记一次K8S集群中etcd数据快照的备份恢复实践
[点击 关注「 全栈工程师修炼指南」公众号 ] 设为「️ 星标」带你从基础入门 到 全栈实践 再到 放弃学习! 涉及 网络安全运维.应用开发.物联网IOT.学习路径 .个人感悟 等知识分享. 希望各位 ...
- mysql容灾备份脚本
一,环境需求 **安装前准备 操作系统环境:Centos 7.2 [root@localhost soft]# rpm -qa | grep mariadb [root@localhost soft] ...
- Redis全方位详解--磁盘持久化和容灾备份
序言 在上一篇博客中,博客介绍了redis的数据类型使用场景和redis分布式锁的正确姿势.我们知道一旦Redis重启,存在redis里面的数据就会全部丢失.所以这篇博客中向大家介绍Redis的磁盘持 ...
随机推荐
- CMake个人理解和使用
前言 CMake是一个构建工具,通过它可以很容易创建跨平台的项目.通常使用它构建项目要分两步,通过源代码生成工程文件,通过工程文件构建目标产物(可能是动态库,静态库,也可能是可执行程序).使用CMak ...
- json数据的解析
php声明没有键的数组,用json_encode输出: $array=array("1","2","3"); echo json_encod ...
- TVM Deploy Runtime[施工中]
本文地址:https://www.cnblogs.com/wanger-sjtu/p/17291070.html tvm 中在部署时有多个选择,最开始的graph exectuor runtime . ...
- Mysql数据库体系化详细笔记(b站韩顺平)
Mysql数据库 一.数据库 使用命令行窗口连接MYSQL数据库 mysql服务启动,在cmd输入net start mysql 1.mysql -h主机名-Р端口-u用户名-p密码 2.登录前,保证 ...
- LocalTime转String类型,如下图
- hexo博客生成报错YAMLException: can not read a block mapping entry
报错信息: YAMLException: can not read a block mapping entry; a multiline key may not b --- title: [转]--I ...
- RabbitMQ 中 exchange、route、queue 的关系
从 AMQP 协议可以看出,MessageQueue.Exchange 和 Binding 构成了 AMQP 协议的核心,下面我们就围绕这三个主要组件 从应用使用的角度全面的介绍如何利用 Rabbit ...
- linux 内核的ksm机制
KSM(Kernel Samepage Merging),是Linux内核中的一种内存优化机制,它能够通过将多个应用程序中的相同内存页合并,实现虚拟内存的节约.KSM通过比较不同进程间的虚拟内存页,如 ...
- EasyExcel中使用表头模板示例
解决方案 在EasyExcel的官方示例中,使用模板导出Excel,其结果仍然还会重新打印表头.不满足使用表头模板的需求.在参考源码后,找到如下解决方案. String templateFileNam ...
- React报错:This is probably not a problem with npm. There is likely additional logging output above.
解决方案 删除node_modules和package-lock.json,之后运行npm cache clear --force,重新安装模块npm install,另外要注意 npm 5.0版本之 ...