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.pswp.cn/bicheng/74669.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/74669.shtml
英文地址,請注明出處:http://en.pswp.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…