使用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

智能推荐

C++重新认知:构造函数和析构函数-程序员宅基地

文章浏览阅读919次,点赞23次,收藏19次。析构函数是一个成员函数,当创建的对象超出范围时或通过调用delete或者时delete[]显式销毁创建的对象时,会自动调用析构函数。当类必须显式释放资源时(),程序员就必须自己定义一个析构函数了。1) 使用了动态分配的内存:当一个类使用了new运算符进行动态内存分配(例如使用了指针或动态数组),那么就需要在析构函数中使用delete或delete[]来释放分配的内存,以防止内存泄漏。2)使用了其他资源:除了内存之外,对象还可能使用其他资源,如文件句柄、网络连接等。

Git(二)分支管理与远程仓库操作_enumerating objects: 21, done. counting objects: 1-程序员宅基地

文章浏览阅读442次。上一次写了Git的简介、安装、版本库创建,文件的创建,修改,删除等操作。这次写写别的文章结构一、远程仓库1、添加远程库2、从远程库克隆一、远程仓库如果只是在一个仓库管理文件历史,Git和其他版本控制系统有啥区别?这篇文章开始,就要深入学习Git了(深呼吸~),作为一个分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上,怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机..._enumerating objects: 21, done. counting objects: 100% (21/21), done. delta c

底部带有Indicator的RadioButton,自定义View -- UnderLineRadioBtn的实现_radiobutton indicator-程序员宅基地

文章浏览阅读628次。github项目地址:https://github.com/Jerry930326/UnderLineRadioBtn前言:该项目实现效果为RadioButton仿照TabLayout底部的Indicator下划线,可通过自定义属性和暴露的方法进行:1、文字默认/选中颜色设置;2、下划线默认/选中颜色设置;3、下划线的宽、高;4、下划线的圆角。实现该效果我先使用了layer-list方式,之后自..._radiobutton indicator

[Python从零到壹] 五十一.图像增强及运算篇之图像灰度直方图对比分析万字详解_python 直方图增强-程序员宅基地

文章浏览阅读5.4k次,点赞8次,收藏47次。欢迎大家来到“Python从零到壹”,在这里我将分享约200篇Python系列文章,带大家一起去学习和玩耍。第二部分将讲解图像运算和图像增强,前面的文章详细介绍了图像灰度变换和阈值变换。本篇文章将结合直方图分别对比图像灰度变换前后的变化,方便读者更清晰地理解灰度变换和阈值变换。希望文章对您有所帮助,如果有不足之处,还请海涵。..._python 直方图增强

TX2刷机和软件安装过程记录_deprecationwarning: pkg_resources is deprecated as-程序员宅基地

文章浏览阅读6.9k次,点赞5次,收藏55次。最近在使用英伟达TX2,在环境配置方面反反复复花了不少时间,踩到了一些坑,做一个记录防止以后又要重装系统准备数据线、键盘、鼠标、显示器少不掉(显示器要支持HDMI接口,我看网上说HDMI转VGA的会黑屏,没有试过)有Ubuntu16或Ubuntu18的虚拟机,或电脑作为主机(Ubuntu20.04不行,因为我电脑就是,第一次装了没法用)有网的环境,而且网速一定要好,我在实验室里网速一般,经常下载失败使用SDKmanager刷机打开准备的Ubuntu系统作为主机注意 如果使用虚拟机需要分配_deprecationwarning: pkg_resources is deprecated as an api

【时序数据库】时间序列数据和MongoDB第三部分-查询、分析和呈现时间序列数据...-程序员宅基地

文章浏览阅读877次。在《时间序列数据和MongoDB:第1部分-简介》「时序数据库」时间序列数据与MongoDB:第一部分-简介中,我们回顾了理解数据库的查询访问模式需要询问的关键问题。在《时间序列数据和MongoDB:第2部分-模式设计最佳实践》「时序数据库」时序数据库和MongoDB第二部分-模式设计最佳实践中,我们探索了时间序列数据的各种模式设计选项,以及它们如何影响MongoDB资源。在这篇博客文章中,我们将..._mongodb存储时序数据

随便推点

【已解决】./nginx: error while loading shared libraries: libssl.so.10: cannot open shared object file: No-程序员宅基地

文章浏览阅读1.8k次。那么需要安装下libssl包:compat-openssl10。_error while loading shared libraries: libssl.so.10: cannot open shared objec

Dell戴尔灵越Inspiron 7700 AIO一体机电脑原厂预装Windows10系统-程序员宅基地

文章浏览阅读969次。灵越7700一体机原装出厂系统自带声卡驱动、无线网卡驱动、面部识别等所有驱动、出厂主题壁纸、系统属性专属LOGO标志、Office办公软件、MyDell等预装程序。由于时间关系,绝大部分资料没有上传,不是想要的型号,请联系客服获取。

ubuntu 18.04无法开机 允许root用户桌面登录_ubuntu无法进入系统网络起不来但是可以用root登录-程序员宅基地

文章浏览阅读2.4k次。教程前提是:已经知道root密码!!!1、开机后选择 “advancedoptionsforubuntu”2、选择带“recovermode”3、选择root一行;4、用vi开始操作: 4.1、vi /usr/share/lightdm/lightdm.conf.d/50-ubuntu.conf 末尾添加以下两行: gre..._ubuntu无法进入系统网络起不来但是可以用root登录

【零基础】手把手教你用Node搭建服务器并连接MongoDB数据库_使用node搭建服务器和数据库-程序员宅基地

文章浏览阅读2.2k次,点赞29次,收藏36次。首次使用Node搭建服务器并连接MongoDB,附MongoDB注册以及创建集群详细教程,快来瞅瞅吧~欢迎小伙伴们一起交流学习~_使用node搭建服务器和数据库

Android系统设置源码分析(ROM)_rom源码分析-程序员宅基地

文章浏览阅读1.2k次,点赞4次,收藏3次。PS:内容很多,花了不少时间。思维导图链接:http://pan.baidu.com/s/1jI3od4E 密码:eqsc_rom源码分析

Facebook开源技术CTO John Kenevey:Facebook开源数据中心-程序员宅基地

文章浏览阅读120次。第六届中国云计算大会于2014年5月20-23日在北京国家会议中心拉开帷幕。本次大会立足实践,以国际化的视野,帮助与会者了解全球云计算技术的发展趋势;从应用出发,探讨交通、医疗、教育、金融、制造、数字娱乐等行业领域的实践经验;并通过技术专场、产品发布和培训课程等方式,深度剖析云计算大数据的核心技术。Facebook公司开源技术CTO John Ke...

推荐文章

热门文章

相关标签