使用rman创建DG---主库db_name与db_unique_name不同-程序员宅基地

技术标签: 操作系统  数据库  大数据  


1、此实验有三个目的


1、使用RMAN的duplicate创建物理备库
2、主库db_name与db_unique_name不同时, 主库要启动到mount状态,才能搭建备库。
3、主库db_name与db_unique_name相同时, 主库开启时(支持业务不中断 ),可以创建备库。


2、容灾基本概念


1、阵列的复制技术(硬件)

通过在阵列之间进行复制,异地保存数据(要求:两边的系统配臵一致,用于大数据量的环境,备份方,可以不设主机,只需要存储设备。         对存储设备和网络环境要求比较高。比如 EMC  存储)

2、基于逻辑卷的复制技术(操作系统层面)

lvlogical volumn)的镜像技术来实现

通过 TCP/IP 网络传输逻辑卷上数据的变化(要求:两边的软、硬件环境必须一致,一般用于大数据量的传递,如 IBM AIX  的逻辑卷的复制技术)

3、基于 Oracle  redo log  的复制(在应用层)

1Data Guard

2Gold Gate

3stream

逻辑复制:  将主库的 redo  log  传递到备库后,然后利用 logminer  的工具,从 redo  log  中解析出 sql 语句,在备库执行,保证和主库同步。(主库和备库可以              是不同的环境,备库可以处于读写状态)

逻辑备库可以看作是一个单独的库(数据库名和 DBID 和主库都不一样)。

物理复制:将主库的 redo log  传递到备库后,备库对 redo log  日志进行 recovery  ,来和主库保持一致。(主库和备库必须是相同的环境,备库一般处于只读状态)              物理的备库和主库是一样的(比如:数据库名、DBID

4Oracle Data Guard

----Oracle  成本最低的容灾技术(Oracle  企业版自动支持,通过主库和备库来实现容灾;一般主库处于生产环境,备库处于备份状态,或者可以利用备库做数据查询、生成报表、数据备份等减轻主库的压力)

---主库将 redo  log 传递到备库上,备库对 redo  log  进行应用(物理---RECOVERY,逻辑-----应用 sql  语句),来保持和主库的同步。


DG 环境:(备库最多可以有 9 个)

1  主库和备库之间都是单实例

2  主库是 RAC  ,备库是单实例

3  主库是 RAC,备库也是 RAC  MAA  实现最高可用性)

------DG  的模式

1、物理 DG  备库接收到主库的 redo log后,做 recover;要求备库环境和主库换将必须一致,备库一般处于 mount 状态,如果 open,只能处于只读状态,并且在             open  状态下不能再做 recover(一般对于物理 DG,可以利用备库进行备份,减轻主库的压力)

2、逻辑 DG  备库收到主库的 redo log  后,对 redo log  抽取 sql  然后进行应用;备库环境可以和主库不一致。备库可以进入 open(读写状态),可以在备库上做查询、报表打印等操作,减轻主库压力;建立逻辑备库之前,必须先建立物理的备库

 


 



点击(此处)折叠或打开

  1. ---环境
  2. --系统
  3. oracle Linux 5.6
  4. --oracle版本
  5. Oracle Database 11g Enterprise Edition Release 11.2.0.4.0

  6. --一、启动到mount状态下创建备库,主库中db_unique_name和DB_NAME不同

  7. --配置说明
  8. primary db
  9. DB_NAME=ENMOEDU
  10. DB_UNIQUE_NAME=ENMOEDU1
  11. standby db
  12. DB_NAME=ENMOEDU
  13. DB_UNIQUE_NAME=ENMOEDU2

  14. --启动至归档,启动强制记日志
  15. SYS@ENMOEDU>startup mount;
  16. SYS@ENMOEDU>alter database archivelog;
  17. SYS@ENMOEDU>alter database force logging;
  18. SYS@ENMOEDU>alter database open;
  19. /*
  20. 默认情况下数据库操作会记录redo log,但是在一些特定的情况下可以使用nologging来不生成redo信息
  21.   (1)表的批量INSERT(通过/*+APPEND */提示使用“直接路径插入“。或采用SQL*Loader直接路径加载)。表数据不生成redo,但是
  22. 所有索引修改会生成redo,但是所有索引修改会生成redo(尽管表不生成日志,但这个表上的索引却会生成redo!)。
  23.   (2)LOB操作(对大对象的更新不必生成日志)。
  24.   (3)通过CREATE TABLE AS SELECT创建表
  25.   (4)各种ALTERe TABLE操作,如MOVE和SPLIT
  26.   (5)在一些表迁移和表空间迁移中,可以使用alter table a nologging;或者alter tablespace snk nologging;在操作完成后再修改回logging状态。
  27.   这里需要多说一句,如果你使用nologging导入大批量数据,以后对这些数据的修改会在redo或者archive log中,但是基准的数据是没有的,所以一旦介质损坏是无法完全恢复的,必须在使用nologging完成切换回logging后,做一次全备或者0级备份。
  28.  */
  29.  
  30.  --在备库上添加 standby log
  31. alter database add standby logfile group 4 '/u01/app/oracle/oradata/ENMOEDU/std_redo04.log' size 50M;
  32. alter database add standby logfile group 5 '/u01/app/oracle/oradata/ENMOEDU/std_redo05.log' size 50M;
  33. alter database add standby logfile group 6 '/u01/app/oracle/oradata/ENMOEDU/std_redo06.log' size 50M;
  34. alter database add standby logfile group 7 '/u01/app/oracle/oradata/ENMOEDU/std_redo07.log' size 50M;
  35.  
  36. --配置tnsnames
  37. --主库
  38. [oracle@prod1 admin]$ vi tnsnames.ora
  39. ENMOEDU2 =
  40.   (DESCRIPTION =
  41.     (ADDRESS_LIST =
  42.       (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.102)(PORT = 1521))
  43.     )
  44.     (CONNECT_DATA =
  45.       (SERVICE_NAME = ENMOEDU)
  46.     )
  47.   )

  48. ENMOEDU1 =
  49.   (DESCRIPTION =
  50.     (ADDRESS_LIST =
  51.       (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.56.101)(PORT = 1521))
  52.     )
  53.     (CONNECT_DATA =
  54.       (SERVER = DEDICATED)
  55.       (SERVICE_NAME = ENMOEDU)
  56.     )
  57.   )
  58. --备库配置静态监听
  59. [oracle@prod2 admin]$ vi listener.ora
  60. SID_LIST_LISTENER =
  61.  (SID_LIST =
  62.   (SID_DESC =
  63.      (GLOBAL_DBNAME = ENMOEDU)
  64.      (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1)
  65.      (SID_NAME = ENMOEDU)
  66.    )
  67.  )
  68.  
  69. ---主库创建pfile
  70. SYS@ENMOEDU>create pfile from spfile;
  71. --修改pfile
  72. DB_UNIQUE_NAME=ENMOEDU1
  73. LOG_ARCHIVE_CONFIG='DG_CONFIG=(ENMOEDU1,ENMOEDU2)'
  74. DB_FILE_NAME_CONVERT='/u01/app/oracle/oradata/ENMOEDU','/u01/app/oracle/oradata/E
  75. NMOEDU'
  76. LOG_FILE_NAME_CONVERT=
  77.  '/u01/arch/','/u01/arch/'
  78. LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
  79. LOG_ARCHIVE_DEST_1=
  80. 'LOCATION=/u01/arch/
  81.   VALID_FOR=(ALL_LOGFILES,ALL_ROLES)
  82.   DB_UNIQUE_NAME=ENMOEDU1'
  83. LOG_ARCHIVE_DEST_2=
  84.  'SERVICE=ENMOEDU2 ASYNC
  85.   VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
  86.   DB_UNIQUE_NAME=ENMOEDU2'
  87. LOG_ARCHIVE_DEST_STATE_1=ENABLE
  88. LOG_ARCHIVE_DEST_STATE_2=ENABLE
  89. REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
  90. STANDBY_FILE_MANAGEMENT=AUTO
  91. FAL_SERVER=ENMOEDU2
  92. fal_client=ENMOEDU1

  93. --通过修改后的pfile重建spfile,启动数据库
  94. SYS@ENMOEDU>create spfile from pfile;
  95. SYS@ENMOEDU>startup mount;


  96. --创建相关目录
  97. mkdir -p /u01/arch/

  98. --拷贝主库文件
  99. [oracle@prod1 u01]$ scp /u01/app/oracle/product/11.2.0/db_1/dbs/ * 192.168.56.102:/u01/app/oracle/product/11.2.0/db_1/dbs
  100. --备库启动到nomount
  101. 注:db_name=ENMOEDU
  102. DB_UNIQUE_NAME=ENMOEDU2
  103. LOG_ARCHIVE_CONFIG='DG_CONFIG=(ENMOEDU2,ENMOEDU1)'
  104. DB_FILE_NAME_CONVERT='/u01/app/oracle/oradata/ENMOEDU','/u01/app/oracle/oradata/ENMOEDU'
  105. LOG_FILE_NAME_CONVERT=
  106.  '/u01/arch/','/u01/arch/'
  107. LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
  108. LOG_ARCHIVE_DEST_1=
  109. 'LOCATION=/u01/arch/
  110.   VALID_FOR=(ALL_LOGFILES,ALL_ROLES)
  111.   DB_UNIQUE_NAME=ENMOEDU2'
  112. LOG_ARCHIVE_DEST_2=
  113.  'SERVICE=ENMOEDU1 SYNC
  114.   VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
  115.   DB_UNIQUE_NAME=ENMOEDU1'
  116. LOG_ARCHIVE_DEST_STATE_1=ENABLE
  117. LOG_ARCHIVE_DEST_STATE_2=ENABLE
  118. REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
  119. STANDBY_FILE_MANAGEMENT=AUTO
  120. FAL_SERVER=ENMOEDU1
  121. fal_client=ENMOEDU2

  122. --rman恢复备库
  123. [oracle@prod1 u01]$rman target sys/oracle@enmoedu1 auxiliary sys/oracle@enmoedu2

  124. RMAN>duplicate target database for standby from active database dorecover nofilenamecheck;
  125. DORECOVER:从目标数据库用归档日志备份恢复备用数据库。
  126. 一旦备用数据库的创建完成,RMAN将对备用数据库应用主数据库中的所有归档日志,一直到RMAN中注册的最新的归档日志。
  127. nofilenamecheck 告诉主库和备库有相同的文件名称

  128. duplicate target database for standby from active database nofilenamecheck;


  129. 备库在 mount下做 media recover

  130. SYS@ENMOEDU>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT FROM SESSION;


  131. --SYS@ENMOEDU>alter database recover managed standby database disconnect from session;
  132. --SYS@ENMOEDU>alter database recover managed standby database cancel;关闭日志传输
  133. --SYS@ENMOEDU>alter database recover managed standby database disconnect from session;

  134. --备库
  135. SYS@ENMOEDU2>alter database open;
  136. --主库
  137. SYS@ENMOEDU1>alter database open;

  138. select GROUP#,SEQUENCE#,MEMBERS,STATUS from v$log;
  139. select max(sequence#) from v$archived_log;
  140. --主库
  141. SYS@ENMOEDU>select name,PROTECTION_MODE,DATABASE_ROLE ,SWITCHOVER_STATUS from v$database;

  142. NAME PROTECTION_MODE DATABASE_ROLE SWITCHOVER_STATUS
  143. --------- -------------------- ---------------- --------------------
  144. ENMOEDU MAXIMUM PERFORMANCE PRIMARY FAILED DESTINATION----此种状态为失败(原因监听没开,或是主库没有启动到mount)
  145. --查看进程,看有没有LNS进程,如果没有
  146. select PROCESS,STATUS from v$managed_standby;

  147. --查看数据库状态
  148.   
  149. SYS@ENMOEDU>select NAME,OPEN_MODE,PROTECTION_MODE,DATABASE_ROLE,SWITCHOVER_STATUS from v$database;




  150. --二、主库启动状态下创建备库,主库中db_unique_name和DB_NAME相同

  151. --(环境已配置完成,创建相关目录已完成)

  152. --配置说明
  153. primary db
  154. DB_NAME=ENMOEDU
  155. DB_UNIQUE_NAME=ENMOEDU
  156. standby db
  157. DB_NAME=ENMOEDU
  158. DB_UNIQUE_NAME=ENMOEDU2

  159. --主库参数文件

  160. DB_UNIQUE_NAME=ENMOEDU
  161. LOG_ARCHIVE_CONFIG='DG_CONFIG=(ENMOEDU,ENMOEDU2)'
  162. DB_FILE_NAME_CONVERT='/u01/app/oracle/oradata/ENMOEDU','/u01/app/oracle/oradata/ENMOEDU'
  163. LOG_FILE_NAME_CONVERT=
  164.  '/u01/arch/','/u01/arch/'
  165. LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
  166. LOG_ARCHIVE_DEST_1=
  167. 'LOCATION=/u01/arch/
  168.   VALID_FOR=(ALL_LOGFILES,ALL_ROLES)
  169.   DB_UNIQUE_NAME=ENMOEDU'
  170. LOG_ARCHIVE_DEST_2=
  171.  'SERVICE=ENMOEDU2 SYNC
  172.   VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
  173.   DB_UNIQUE_NAME=ENMOEDU2'
  174. LOG_ARCHIVE_DEST_STATE_1=ENABLE
  175. LOG_ARCHIVE_DEST_STATE_2=ENABLE
  176. REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
  177. STANDBY_FILE_MANAGEMENT=AUTO
  178. FAL_SERVER=ENMOEDU2
  179. fal_client=ENMOEDU

  180. --主库启动业务可以继续


  181. --备库参数文件

  182. DB_UNIQUE_NAME=ENMOEDU2
  183. LOG_ARCHIVE_CONFIG='DG_CONFIG=(ENMOEDU,ENMOEDU2)'
  184. DB_FILE_NAME_CONVERT='/u01/app/oracle/oradata/ENMOEDU','/u01/app/oracle/oradata/ENMOEDU'
  185. LOG_FILE_NAME_CONVERT=
  186.  '/u01/arch/','/u01/arch/'
  187. LOG_ARCHIVE_FORMAT=log%t_%s_%r.arc
  188. LOG_ARCHIVE_DEST_1=
  189. 'LOCATION=/u01/arch/
  190.   VALID_FOR=(ALL_LOGFILES,ALL_ROLES)
  191.   DB_UNIQUE_NAME=ENMOEDU'
  192. LOG_ARCHIVE_DEST_2=
  193.  'SERVICE=ENMOEDU2 SYNC
  194.   VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
  195.   DB_UNIQUE_NAME=ENMOEDU2'
  196. LOG_ARCHIVE_DEST_STATE_1=ENABLE
  197. LOG_ARCHIVE_DEST_STATE_2=ENABLE
  198. REMOTE_LOGIN_PASSWORDFILE=EXCLUSIVE
  199. STANDBY_FILE_MANAGEMENT=AUTO
  200. FAL_SERVER=ENMOEDU2
  201. fal_client=ENMOEDU




来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31324783/viewspace-2122466/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31324783/viewspace-2122466/

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/cmkhmr7984/article/details/100298932

智能推荐

874计算机科学基础综合,2018年四川大学874计算机科学专业基础综合之计算机操作系统考研仿真模拟五套题...-程序员宅基地

文章浏览阅读1.1k次。一、选择题1. 串行接口是指( )。A. 接口与系统总线之间串行传送,接口与I/0设备之间串行传送B. 接口与系统总线之间串行传送,接口与1/0设备之间并行传送C. 接口与系统总线之间并行传送,接口与I/0设备之间串行传送D. 接口与系统总线之间并行传送,接口与I/0设备之间并行传送【答案】C2. 最容易造成很多小碎片的可变分区分配算法是( )。A. 首次适应算法B. 最佳适应算法..._874 计算机科学专业基础综合题型

XShell连接失败:Could not connect to '192.168.191.128' (port 22): Connection failed._could not connect to '192.168.17.128' (port 22): c-程序员宅基地

文章浏览阅读9.7k次,点赞5次,收藏15次。连接xshell失败,报错如下图,怎么解决呢。1、通过ps -e|grep ssh命令判断是否安装ssh服务2、如果只有客户端安装了,服务器没有安装,则需要安装ssh服务器,命令:apt-get install openssh-server3、安装成功之后,启动ssh服务,命令:/etc/init.d/ssh start4、通过ps -e|grep ssh命令再次判断是否正确启动..._could not connect to '192.168.17.128' (port 22): connection failed.

杰理之KeyPage【篇】_杰理 空白芯片 烧入key文件-程序员宅基地

文章浏览阅读209次。00000000_杰理 空白芯片 烧入key文件

一文读懂ChatGPT,满足你对chatGPT的好奇心_引发对chatgpt兴趣的表述-程序员宅基地

文章浏览阅读475次。2023年初,“ChatGPT”一词在社交媒体上引起了热议,人们纷纷探讨它的本质和对社会的影响。就连央视新闻也对此进行了报道。作为新传专业的前沿人士,我们当然不能忽视这一热点。本文将全面解析ChatGPT,打开“技术黑箱”,探讨它对新闻与传播领域的影响。_引发对chatgpt兴趣的表述

中文字符频率统计python_用Python数据分析方法进行汉字声调频率统计分析-程序员宅基地

文章浏览阅读259次。用Python数据分析方法进行汉字声调频率统计分析木合塔尔·沙地克;布合力齐姑丽·瓦斯力【期刊名称】《电脑知识与技术》【年(卷),期】2017(013)035【摘要】该文首先用Python程序,自动获取基本汉字字符集中的所有汉字,然后用汉字拼音转换工具pypinyin把所有汉字转换成拼音,最后根据所有汉字的拼音声调,统计并可视化拼音声调的占比.【总页数】2页(13-14)【关键词】数据分析;数据可..._汉字声调频率统计

linux输出信息调试信息重定向-程序员宅基地

文章浏览阅读64次。最近在做一个android系统移植的项目,所使用的开发板com1是调试串口,就是说会有uboot和kernel的调试信息打印在com1上(ttySAC0)。因为后期要使用ttySAC0作为上层应用通信串口,所以要把所有的调试信息都给去掉。参考网上的几篇文章,自己做了如下修改,终于把调试信息重定向到ttySAC1上了,在这做下记录。参考文章有:http://blog.csdn.net/longt..._嵌入式rootfs 输出重定向到/dev/console

随便推点

uniapp 引入iconfont图标库彩色symbol教程_uniapp symbol图标-程序员宅基地

文章浏览阅读1.2k次,点赞4次,收藏12次。1,先去iconfont登录,然后选择图标加入购物车 2,点击又上角车车添加进入项目我的项目中就会出现选择的图标 3,点击下载至本地,然后解压文件夹,然后切换到uniapp打开终端运行注:要保证自己电脑有安装node(没有安装node可以去官网下载Node.js 中文网)npm i -g iconfont-tools(mac用户失败的话在前面加个sudo,password就是自己的开机密码吧)4,终端切换到上面解压的文件夹里面,运行iconfont-tools 这些可以默认也可以自己命名(我是自己命名的_uniapp symbol图标

C、C++ 对于char*和char[]的理解_c++ char*-程序员宅基地

文章浏览阅读1.2w次,点赞25次,收藏192次。char*和char[]都是指针,指向第一个字符所在的地址,但char*是常量的指针,char[]是指针的常量_c++ char*

Sublime Text2 使用教程-程序员宅基地

文章浏览阅读930次。代码编辑器或者文本编辑器,对于程序员来说,就像剑与战士一样,谁都想拥有一把可以随心驾驭且锋利无比的宝剑,而每一位程序员,同样会去追求最适合自己的强大、灵活的编辑器,相信你和我一样,都不会例外。我用过的编辑器不少,真不少~ 但却没有哪款让我特别心仪的,直到我遇到了 Sublime Text 2 !如果说“神器”是我能给予一款软件最高的评价,那么我很乐意为它封上这么一个称号。它小巧绿色且速度非

对10个整数进行按照从小到大的顺序排序用选择法和冒泡排序_对十个数进行大小排序java-程序员宅基地

文章浏览阅读4.1k次。一、选择法这是每一个数出来跟后面所有的进行比较。2.冒泡排序法,是两个相邻的进行对比。_对十个数进行大小排序java

物联网开发笔记——使用网络调试助手连接阿里云物联网平台(基于MQTT协议)_网络调试助手连接阿里云连不上-程序员宅基地

文章浏览阅读2.9k次。物联网开发笔记——使用网络调试助手连接阿里云物联网平台(基于MQTT协议)其实作者本意是使用4G模块来实现与阿里云物联网平台的连接过程,但是由于自己用的4G模块自身的限制,使得阿里云连接总是无法建立,已经联系客服返厂检修了,于是我在此使用网络调试助手来演示如何与阿里云物联网平台建立连接。一.准备工作1.MQTT协议说明文档(3.1.1版本)2.网络调试助手(可使用域名与服务器建立连接)PS:与阿里云建立连解释,最好使用域名来完成连接过程,而不是使用IP号。这里我跟阿里云的售后工程师咨询过,表示对应_网络调试助手连接阿里云连不上

<<<零基础C++速成>>>_无c语言基础c++期末速成-程序员宅基地

文章浏览阅读544次,点赞5次,收藏6次。运算符与表达式任何高级程序设计语言中,表达式都是最基本的组成部分,可以说C++中的大部分语句都是由表达式构成的。_无c语言基础c++期末速成