dataguard环境破坏后采用rman备份集重新部署

news2024/11/18 12:18:08

dataguard环境破坏后采用rman备份集重新部署

1. 环境

主库:    192.168.1.118
备库:    192.168.1.85
OS:      Centos7
DB:      11.2.0.4
前提条件:dataguard之前已经搭建好,从库的spfile和密码文件不需要创建,主库的数据文件目录在从库必须存在,这里的场景是主库的数据文件目录和从库的数据文件目录需要保持一致.

2. 主库备份

run{
allocate channel ch1 device type disk;
backup as compressed backupset format '/home/oracle/rman_backup/df_t%t_s%s_p%p' database;
sql 'alter system archive log current';
backup as compressed backupset format '/home/oracle/rman_backup/archive_log_t%t_s%s_p%p' archivelog all;
backup current controlfile for standby format '/home/oracle/rman_backup/ctl_for_std.bak' tag 'std controlfile';
release channel ch1;
}
 

3.备份集拷贝到从库

scp ctl_for_std.bak oracle@192.168.1.85:/tmp/rman_bak
scp df_t1026569938_s769_p1 oracle@192.168.1.85:/tmp/rman_bak
scp df_t1026570043_s770_p1 oracle@192.168.1.85:/tmp/rman_bak

4. 关闭从库

先查出原来从库的数据库的数据文件路径,等下我们要删除这些文件

SQL> set linesize 1000;
SQL> Select file#,Name From v$datafile;

     FILE# NAME
---------- ------------------------------------------------------------
         1 /u01/app/oracle/oradata/slnngkdg/system01.dbf
         2 /u01/app/oracle/oradata/slnngkdg/sysaux01.dbf
         3 /u01/app/oracle/oradata/slnngkdg/undotbs01.dbf
         4 /u01/app/oracle/oradata/slnngkdg/users01.dbf
         5 /u01/app/oracle/oradata/slnngkdg/tps_data01.dbf
         6 /u01/app/oracle/oradata/slnngkdg/mrkt.dbf
         7 /u01/app/oracle/oradata/slnngkdg/tps_data02.dbf
         8 /u01/app/oracle/oradata/tps_data02.dbf
         9 /u01/app/oracle/oradata/slnngkdg/tps_data04.dbf
        10 /u01/app/oracle/oradata/tps_data05.dbf
        11 /u01/app/oracle/oradata/tps_data06.dbf
        12 /u01/app/oracle/oradata/tps_data07.dbf
        13 /u01/app/oracle/oradata/tps_data08.dbf
        14 /u02/oradata/tps_data09.dbf
        15 /u02/oradata/tps_data10.dbf
        16 /u01/app/oracle/oradata/tps_data11.dbf
        17 /u02/oradata/tps_data12.dbf
        18 /u01/app/oracle/oradata/slnngkdg/tps_data13.dbf
        19 /u01/app/oracle/oradata/tps_data14.dbf

19 rows selected.

 SQL>shutdown immediate

 

5. 删除从库的相应数据文件

rm /u01/app/oracle/oradata/*
rm /u02/oradata/*
rm /u01/app/oracle/oradata/slnngkdg/*

 注意这里控制文件不需要删除

 或是采用dbca进行删除

dbca -silent -deleteDatabase -sourcedb slnngkdg -sid slnngkdg

6. 从库恢复控制文件(系统根据控制文件参数指定的目录复制多份)

RMAN>startup nomount;
RMAN>restore standby controlfile from '/tmp/rman_bak/ctl_for_std.bak';
RMAN>alter database mount;

RMAN> restore standby controlfile from '/tmp/rman_bak/ctl_for_std.bak';

Starting restore at 27-AUG-20
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=19 device type=DISK

channel ORA_DISK_1: restoring control file
channel ORA_DISK_1: restore complete, elapsed time: 00:00:01
output file name=/u01/app/oracle/oradata/slnngkdg/control01.ctl
output file name=/u01/app/oracle/oradata/slnngkdg/control02.ctl
output file name=/u01/app/oracle/oradata/slnngkdg/control03.ctl
Finished restore at 27-AUG-20
 

或是具体指定路径

restore standby controlfile to '/u01/app/oracle/oradata/slnngkdg/control01.ctl' from '/u01/app/rmanbak/ctl_for_std.bak';
restore standby controlfile to '/u01/app/oracle/oradata/slnngkdg/control02.ctl' from '/u01/app/rmanbak/ctl_for_std.bak';
restore standby controlfile to '/u01/app/oracle/oradata/slnngkdg/control03.ctl' from '/u01/app/rmanbak/ctl_for_std.bak';

7.从库注册主库拷贝过来的备份集
RMAN> catalog start with '/tmp/rman_bak';

8. 备库恢复
RMAN>restore database;

 9.添加standby日志组

SQL> select group#,bytes from v$log;

    GROUP#      BYTES
---------- ----------
         1   52428800
         2   52428800
         3   52428800

日志组序号从4开始,大小跟redo log保持一致

SQL> alter database add standby logfile group 4 '/u01/app/oracle/oradata/slnngkdg/standby_redo01.log' size 50m reuse;
SQL> alter database add standby logfile group 5 '/u01/app/oracle/oradata/slnngkdg/standby_redo02.log' size 50m reuse;
SQL> alter database add standby logfile group 6 '/u01/app/oracle/oradata/slnngkdg/standby_redo03.log' size 50m reuse;

10.日志应用
alter database recover managed standby database using current logfile disconnect from session;

11.打开数据库
应用日志
alter database recover managed standby database using current logfile disconnect from session;

等日志应用同步完成后退出日志应用,然后打开数据库,否则打开数据库的时候也会先应用日志,等日志应用追上来了后才能打开数据库

alter database recover managed standby database cancel;
alter database open;

然后启用日志应用
alter database recover managed standby database using current logfile disconnect from session;

12.online redo和temp文件不需要创建

打开数据库的时候,日志信息会有如下的输出:

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

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

相关文章

请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m的k个素数存入xx所指的数组中。

本文收录于专栏:算法之翼 https://blog.csdn.net/weixin_52908342/category_10943144.html 订阅后本专栏全部文章可见。 本文含有题目的题干、解题思路、解题思路、解题代码、代码解析。本文分别包含C语言、C++、Java、Python四种语言的解法和详细的解析。 题干 请编写一个函…

TVbox三端助手MAC+Windows+手机版带接口

Vbox这个目前大热的电视播放器,由于是空壳,于是接口成为非常核心的一环,很多网友制作的接口会进行加密,以防被人复制使用。 最近发现有人对此做了个专门解密的工具,解不解密的不重要的,分享迷倒是觉得这工…

树莓集团与企业协同育人,打造成都数字产业人才培养高地

树莓集团,作为成都数字产业的重要力量,深知企业协同育人的重要性。我们坚信,通过校企合作的模式,可以从供给侧结构性改革的角度出发,开展精准、高效的人才培养工作。我们既是企业,也是产业的代表&#xff0…

VUE识别图片文字OCR(tesseract.js)

效果:1&#xff1a; 效果图2&#xff1a; 一、安装tesseract.js npm i tesseract.js 二、静态页面实现 <template><div><div style"marginTop:100px"><input change"handleChage" type"file" id"image-input"…

uniapp使用腾讯地图实现商家定位

uniapp使用腾讯地图实现商家定位 一丶申请腾讯位置服务开发者密钥二丶下载微信小程序JavaScriptSDK三丶安全域名设置四、代码编写五、实现效果 一丶申请腾讯位置服务开发者密钥 官网教程&#xff1a;微信小程序JavaScript SDK | 腾讯位置服务 点击申请密钥 创建应用&#xf…

Hive 中常用的函数以及数据类型

数据类型 1.基本数据类型: 数据类型大小范围示例TINYINT1byte-128 ~ 127100YSMALLINT2byte-32768 ~ 32767100SINT4byte-2^32~ 2^32-1100BIGINT8byte-2^64~ 2^64-1100LFLOAT4byte单精度浮点数5.21DOUBLE8byte双精度浮点数5.21DECIMAL-高精度浮点数DECIMAL(9,8)BOOLEAN-布尔型tr…

Windows系统下安装paddle

开始使用_飞桨-源于产业实践的开源深度学习平台 (paddlepaddle.org.cn) 命令行下&#xff1a; python -m pip install --upgrade pip --user python -m pip install paddlepaddle2.6.1 -i https://pypi.tuna.tsinghua.edu.cn/simple 报异常 ERROR: Could not install packa…

力扣HOT100 - 24. 两两交换链表中的节点

解题思路&#xff1a; 递归 class Solution {public ListNode swapPairs(ListNode head) {if (head null || head.next null) {return head;}ListNode newHead head.next;head.next swapPairs(newHead.next);newHead.next head;return newHead;} }

nvm版本控制nvm list available报错

# 配置node镜像&#xff1a; node_mirror: https://npmmirror.com/mirrors/node/ # 配置npm镜像&#xff1a; npm_mirror: https://npmmirror.com/mirrors/npm/ 2024.4.22换域名了&#xff0c;改成这个才能用别的不行

护眼灯真的可以保护眼睛吗?揭秘护眼台灯五大骗局!

护眼台灯作为书房中必不可少的工具之一&#xff0c;基本家家户户都有&#xff0c;但是&#xff0c;随着需求的增加&#xff0c;越来越多不专业的台灯品牌进入市场&#xff0c;这种品牌下的产品不仅质量差&#xff0c;而且使用久了还会出现近视加深、散光等风险&#xff0c;导致…

Linux-缓冲区(简单理解)

1. 缓冲区是什么 缓冲区就是一段内存空间。 2. 为什么要有缓冲区 IO写入有两种&#xff1a; 写透模式&#xff08;WT&#xff09; 成本高&#xff0c;效率低写回模式&#xff08;WB&#xff09; 成本低&#xff0c;效率高 写透模式&#xff1a;每次的文件写入都要立即刷新…

绿联搭建rustdesk服务器

绿联搭建rustdesk服务器&#xff0c;不再使用向日葵 注意&#xff1a;本服务器需要有动态公网IP以及自己的域名&#xff0c;ipv6未测试。 1. 拉取镜像 rustdesk/rustdesk-server-s6:latest 注意是这个-s6的镜像。 2. 部署镜像 2.1 内存配置 本服务器比较省内存&#xff0…

基于Springboot+Vue的Java项目-在线文档管理系统开发实战(附演示视频+源码+LW)

大家好&#xff01;我是程序员一帆&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;Java毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计 &am…

Unity 对APK签名

关键代码 PS D:\UnityProject\YueJie> jarsigner -verbose -keystore D:\UnityProject\YueJie\user.keystore -signedjar D:\UnityProject\YueJie\meizuemptyapk-release-signed.apk D:\UnityProject\YueJie\MeizuEmpty-release-unsigned.apk 1 示例 # jarsigner的命令格…

免费升级网站http改为https

目录 首先带大家一起先了解一下http的定义、历史、优势以及缺陷。 简述HTTPS的原理和加密逻辑&#xff1a; 免费且不花钱就能实现网站的https访问方式&#xff1a; 很多人可能都发现了&#xff0c;在浏览网页时&#xff0c;最常见的是http访问&#xff0c;但是也有一部分网站…

YashanDB连获多项权威认证

近期&#xff0c;YashanDB产品能力再获认可&#xff0c;顺利通过多项权威测试认证&#xff0c;包括通过《数据库政府采购需求标准(2023年版)》测评&#xff1b;通过国密检测机构测试&#xff0c;产品支持GB/T38636-2020《信息安全技术传输层密码协议(TLCP)》国标协议&#xff1…

Centos7.9安装rabbitmq

1. 概述 AMQP&#xff0c;即 Advanced Message Queuing Protocol&#xff08;高级消息队列协议&#xff09;&#xff0c;是一个网络协议&#xff0c;是应用层协议的一个开放标准&#xff0c;为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息&#xff0c;并不…

Jackson知识点记录

文章目录 一.Jackson模块说明 二.ObjectMapper基本功能使用ObjectMapper的一些核心方法&#xff1a;示例代码1. 序列化示例2. 反序列化示例3. JsonNode 处理示例 高级配置 三.各种Node1. ObjectNode2. ArrayNode3. ValueNode4. MissingNode示例 一.Jackson Jackson 库主要分为…

安泰电子 :高压功率放大器设计方案有哪些

高压功率放大器是现代通信和电子设备中不可或缺的关键组件。它能够将低功率信号放大到足够的功率水平&#xff0c;以便在各种应用中实现远距离传输和覆盖范围。下面西安安泰电子将介绍高压功率放大器的设计方案&#xff0c;包括电路拓扑、元件选择、功率损耗和失真控制等方面的…

vue3的getCurrentInstance获取当前组件实例

vue3的setup中没有this时需要使用getCurrentInstance()来获取。 在 Vue 3 中&#xff0c;getCurrentInstance 方法可以在组合式 API&#xff08;Composition API&#xff09;中获取当前组件实例。这个方法返回一个包含了组件实例的对象&#xff0c;你可以用它来访问组件的 pro…