Oracle-rman restore遭遇RMAN-03002与ORA-19563

文章目录

  • 在原DB上检查是否有重复的文件名:
  • 查看rman恢复的日志
  • 修正重名部分
  • 重新执行rman恢复
  • 结论:

在 RMAN 恢复过程中,遇到RMAN-03002连同ORA-19563:错误。
操作是将 Oracle 10.0.5的数据库备份从 RMAN備份恢复到另一台测试主机的同一个目录。

......
channel ORA_DISK_1: restore complete, elapsed time: 00:26:25
Finished restore at 24-MAR-25RMAN-00571: ===========================================================
RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============
RMAN-00571: ===========================================================
RMAN-03002: failure of switch command at 03/24/2025 22:19:47
ORA-19563:  header validation failed for fileRecovery Manager complete

在MOS 文档 《RMAN Duplicate Fails With RMAN-06136 ORA-19563》(Doc ID 453123.1) 提到可能存在重复的文件名,这一点提供了关键线索。

在原DB上检查是否有重复的文件名:

select substr ( file_name, instr( file_name, '/', -1)) file_name, count(*) from dba_data_files 
group by substr( file_name,instr( file_name, '/', -1))  having count(*) > 1

输出:

FILE_NAME              COUNT(*)
-------------------- ----------
/CES_DATA16.dbf               2

输出结果显示/CES_DATA16.dbf 存在重名

查看rman恢复的日志

......
22> SET NEWNAME FOR DATAFILE '/u2/PCICES/ORADATA/PCICES/CES_DATA15.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA15.dbf';
23> SET NEWNAME FOR DATAFILE '/u2/PCICES/ORADATA/PCICES/CES_DATA16.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA16.dbf';
24> SET NEWNAME FOR DATAFILE '/u3/ORADATA/PCICES/CES_DATA16.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA16.dbf';
25> SET NEWNAME FOR DATAFILE '/u3/ORADATA/PCICES/CES_DATA17.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA17.dbf';
......

日志中,行23与24确实存在重复的文件名,并且由于restore的目标均位于/oracle/oradata/CPS_QAS目录,导致前者被后者覆盖,进而产生该错误。

修正重名部分

这里分别将名称CES_DATA16.dbf修改为CES_DATA16a.dbf与CES_DATA16b.dbf

......
SET NEWNAME FOR DATAFILE '/u2/PCICES/ORADATA/PCICES/CES_DATA16.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA16a.dbf';
SET NEWNAME FOR DATAFILE '/u3/ORADATA/PCICES/CES_DATA16b.dbf' TO '/oracle/oradata/CPS_QAS/CES_DATA16.dbf';
......

重新执行rman恢复

rman target /  cmdfile='/home/oracle/restoredb.rman' log='/home/oracle/rman.20250325.log'

结论:

在 RMAN 备份恢复至不同环境 时,应提前检查 是否存在重名数据文件,并确保 SET NEWNAME 映射的目标文件名唯一,以避免覆盖导致的恢复失败。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/74669.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

运维网络排查工具介绍与使用

作为一名运维工程师,日常工作中最令人头疼的莫过于各种网络故障。在过去一年半的运维生涯中,我积累了丰富的网络故障排查经验,今天就来和大家分享一下如何运用抓包工具(Wireshark、tcpdump)和网络排查工具(…

解决vscode终端和本地终端python版本不一致的问题

🌿 问题描述 本地终端: vscode终端: 别被这个给骗了,继续往下看: 难怪我导入一些包的时候老提示找不到,在本地终端就不会这样,于是我严重怀疑vscode中的python版本和终端不一样&#xff0c…

Sublime全局搜索快捷键Ctrl+Shift+F不能使用解决

问题描述: 在安装好Sublime后,我们使用快捷键进行全局搜索,发现没有反应,但是中文输入变成了繁体。 解决方案: 如截图,在关闭简繁切换的快捷键或者换成其他的就行

海康HTTP监听报警事件数据

http监听接收报警事件数据 海康获取设备报警事件数据两种方式: 1、sdk 布防监听报警事件数据,服务端布防。(前面文章有示例) 2、http监听接收报警事件数据,设备直接推送。 http监听接收报警事件数据,服务端可以使用n…

Python----计算机视觉处理(Opencv:图像边缘检测:非极大值抑制,双阈值筛选)

一、 高斯滤波 边缘检测本身属于锐化操作,对噪点比较敏感,所以需要进行平滑处理。这里使用的是一个5*5的高斯 核对图像进行消除噪声。 二、计算图像的梯度和方向 三、非极大值抑制 在得到每个边缘的方向之后,其实把它们连起来边缘检测就算完了…

Maven工具学习使用(四)——仓库

仓库分类 对于Mavne来说,仓库只分为两类:本地仓库和远程仓库。当Maven根据坐标查询寻找构件的时候,它首先会查看本地仓库,如果本地仓库存在此构件,则直接使用;如果本地仓库不存在此构件,或者需要查看是否有更新的构件版本,Maven就会去远程仓库查找,发现需要的构件之后…

Axure PR 9.0(发音:Ack-sure)原型图工具入门教程:链接交互

文章目录 引言Axure‌ RP 9I Axure RP9入门介绍元件库对两个元件进行连接页面:导航视图、概要母版交互II 链接交互从A页面跳转到B页面返回之前的页面see also引言 【 产品原型图】核心价值和实际应用场景:可视化需求,统一团队理解 https://blog.csdn.net/z929118967/articl…

docker远程debug

1. 修改 Java 启动命令 在 Docker 容器中启动 Java 程序时,需要添加 JVM 调试参数,jdk8以上版本 java -agentlib:jdwptransportdt_socket,servery,suspendn,address*:5005 -jar your-app.jar jdk8及以下版本: java -Xdebug -Xrunjdwp:tra…

K8S学习之基础五十四:jenkins新建测试流水线

jenkins新建测试流水线 新建任务 node(testak) {stage(第1步:从gitee上下载源代码) {git url: "https://gitee.com/akang007/jenkins-sample"script {build_tag sh(returnStdout: true, script: git rev-parse --short HEAD).trim()}}stage(第2步:基…

SylixOS 中 select 原理及使用分析

1、select接口简介 1.1 select接口使用用例 select 是操作系统多路 I/O 复用技术实现的方式之一。 select 函数允许程序监视多个文件描述符,等待所监视的一个或者多个文件描述符变为“准备好”的状态。所谓的”准备好“状态是指:文件描述符不再是阻塞状…

Spring WebFlux之ServerWebExchange

ServerWebExchange 是 Spring WebFlux 中的一个核心接口,用于表示服务器端处理的 HTTP 请求和响应。它封装了请求和响应的所有信息,并提供了相应的方法来操作这些信息。ServerWebExchange 在响应式编程模型中扮演着关键角色,支持非阻塞、异步…

Flutter 常见错误和坑

1. 状态管理问题 StatefulWidget 生命周期误用 // 错误:在 build 方法中修改状态 override Widget build(BuildContext context) {setState(() { counter; }); // 会导致无限重建循环return Text($counter); }// 正确:在事件处理中修改状态 Widget bui…

C++智能指针万字详细讲解(包含智能指针的模拟实现)

在笔试,面试中智能指针经常出现,如果你对智能指针的作用,原理,用法不了解,那么可以看看这篇博客讲解,此外本博客还简单模拟实现了各种指针,在本篇的最后还应对面试题对智能指针的知识点进行了拓…

【Go】Go语言结构体笔记

整体介绍 虽然 Go 语言不是传统意义上的面向对象语言,但它提供了结构体(struct)来组织数据,并且可以为结构体绑定方法,从而达到面向对象的部分效果。 关键知识点包括: 结构体定义与实例化 定义结构体时使用…

Three.js 快速入门教程【十八】射线拾取模型——鼠标点击屏幕选中模型或物体

系列文章目录 Three.js 快速入门教程【一】开启你的 3D Web 开发之旅 Three.js 快速入门教程【二】透视投影相机 Three.js 快速入门教程【三】渲染器 Three.js 快速入门教程【四】三维坐标系 Three.js 快速入门教程【五】动画渲染循环 Three.js 快速入门教程【六】相机控件 Or…

Object.defineProperty()Proxy详解(Vue23数据劫持实现)

底层原理👇🏿 总结一下,结构应该包括: 1. 方法的基本作用和参数。 2. 数据描述符和存取描述符的区别。 3. 属性定义的内部处理流程。 4. 在Vue中的应用实例。 5. 常见错误和正确实践。 每个部分都要结合搜索结果的信息&…

MySQL 进阶语法:函数、约束、多表查询、事务

目录 一、MySQL 常用函数 1. 字符串函数 1.1 基本字符串操作 1.2 字符串截取与处理 1.3 字符串搜索与替换 2. 数值函数 2.1 基本数学运算 2.2 数学计算 2.3 随机数与符号 3. 日期时间函数 3.1 获取当前时间 3.2 日期时间计算 3.3 日期时间提取 3.4 日期时间格式化…

第 12 章(番外)| Solidity 安全前沿趋势 × 审计生态 × 职业路径规划

🌐 第 12 章(番外)| Solidity 安全前沿趋势 审计生态 职业路径规划 ——做得了审计,也接得了项目,走进 Web3 安全工程师的职业实战地图 ✅ 本章导读 Solidity 安全,不只是代码安全、业务安全、审计安全…

1、pytest基本用法

目录 先给大家分享下学习资源 1. 安装pytest 2. 编写用例规则 3. 执行用例 最近在学习pytest的用法 并且用这套框架替换了原来的unittest, 同是测试框架 确实感觉到pytest更加便捷 这边分享给大家我得学习心得 先给大家分享下学习资源 1 官方文档 pytest 官方…

【sylar-webserver】5 协程调度模块

文章目录 设计思路三种协程的切换 协程调度模块,需要把前面的线程模块和协程模块结合使用 ~ 设计思路 构造函数定义 线程池 基本信息。start(),创建线程池,每个线程创建都执行 run()。每个线程在 run() 里,查找任务队列 m_tasks…