Oracle 10G DataGuard搭建

前面我们有讲到Oracle 11G DataGuard的搭建,10G的搭建也是大同小异.不过Oracle 10G不支持Standby open

环境:

角色 主机名 IP 数据库版本 操作系统版本
Primary fdb1 192.168.10.8 10.2.0.1 CentOS 5.11 x86_64
Standby fdb2 192.168.10.9 10.2.0.1 CentOS 5.11 x86_64

在fdb1的/etc/hosts中加入(fdb1)

127.0.0.1 fdb1
192.168.10.9    fdb2

在fdb2的/etc/hosts中加入(fdb2)

127.0.0.1 fdb2
192.168.10.8    fdb1

创建必要的目录(fdb1,fdb2)

mkdir -p /opt/oracle/flash_recovery_area
mkdir -p /opt/oracle/admin/fengdb/{a,b,c,u}dump
mkdir /opt/oracle/oradata/fengdb -p
mkdir -p /opt/oracle/dbackup
mkdir -p /opt/oracle/flash_recovery_area/fengdb/archivelog

查看当前的redo组(fdb1)

select group#,member from v$logfile;
//增加standby日志组
alter database add standby logfile (‘/opt/oracle/oradata/fengdb/standby04.log‘) size 50m;
alter database add standby logfile (‘/opt/oracle/oradata/fengdb/standby05.log‘) size 50m;
alter database add standby logfile (‘/opt/oracle/oradata/fengdb/standby06.log‘) size 50m;
alter database add standby logfile (‘/opt/oracle/oradata/fengdb/standby07.log‘) size 50m;

创建原始参数文件用于备份(fdb1)

create pfile=‘/tmp/fengdb.pfile.ori‘ from spfile;

修改相关参数用于DataGuard环境,注意此处与Oracle 11G不同(fdb1)

alter system set db_unique_name=fdb1 scope=spfile;
alter system set log_archive_config=‘dg_config=(fdb1,fdb2)‘ scope=spfile;
alter system set log_archive_dest_1= ‘location=/opt/oracle/flash_recovery_area/fengdb/archivelog valid_for=(all_logfiles,all_roles)  db_unique_name=fdb1‘ scope=spfile;
alter system set log_archive_dest_2= ‘service=fdb2 async  valid_for=(online_logfiles,primary_role)  db_unique_name=fdb2‘ scope=spfile;
alter system set log_archive_dest=‘‘ scope=spfile;
alter system set log_archive_dest_state_1=enable scope=spfile;
alter system set log_archive_dest_state_2=enable scope=spfile;
alter system set standby_file_management=auto scope=spfile;
alter system set fal_server=fdb2 scope=spfile;
alter system set fal_client=fdb1 scope=spfile;
alter system set db_file_name_convert=‘/opt/oracle/flash_recovery_area‘,‘/opt/oracle/flash_recovery_area‘ scope=spfile;
alter system set log_file_name_convert=‘/opt/oracle/flash_recovery_area‘,‘/opt/oracle/flash_recovery_area‘ scope=spfile;

注意:与Oracle 11G不同的地方有:

alter system set log_archive_dest=‘‘ scope=spfile;

否则可能出现ORA-16019: cannot use LOG_ARCHIVE_DEST_1 with LOG_ARCHIVE_DEST or LOG_ARCHIVE_DUPLEX_DEST

以及上面都是直接修改spfile的,不修改当前运行中的参数

scope=spfile

执行上面的语句其实就是改了下面的一些参数


*.db_unique_name=‘fdb1‘

*.log_archive_config=‘dg_config=(fdb1,fdb2)‘

*.log_archive_dest_1=‘location=/opt/oracle/flash_recovery_area/fengdb/archivelog valid_for=(all_logfiles,all_roles)  db_unique_name=fdb1‘

*.log_archive_dest_2=‘service=fdb2 async  valid_for=(online_logfiles,primary_role)  db_unique_name=fdb2‘

*.log_archive_dest_state_1=‘ENABLE‘

*.log_archive_dest_state_2=‘ENABLE‘

*.standby_file_management=‘AUTO‘

*.fal_client=‘fdb1‘

*.fal_server=‘fdb2‘

*.db_file_name_convert=‘/opt/oracle/flash_recovery_area‘,‘/opt/oracle/flash_recovery_area‘

*.log_file_name_convert=‘/opt/oracle/flash_recovery_area‘,‘/opt/oracle/flash_recovery_area‘

*.log_archive_dest=‘‘

重启数据库以使数据库生效(fdb1)

shutdown  immediate
startup

修改监听(fdb1)

vim $ORACLE_HOME/network/admin/tnsnames.ora

fdb1 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = fdb1)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = fdb1)
    )
  )

fdb2 =
  (DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = fdb2)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = fdb2)
    )
  )

RMAN备份(fdb1)

rman target /
run{
allocate channel c1 type disk;
backup format ‘/opt/oracle/dbackup/fengdb_%T_%s_%p‘ database;
sql ‘alter system archive log current‘;
backup format ‘/opt/oracle/dbackup/archive_log_%T_%s_%p‘ archivelog all;
backup spfile format ‘/opt/oracle/dbackup/spfile_%u_%T.bak‘;
release channel c1;
}
copy current controlfile for standby to ‘/opt/oracle/dbackup/standby.ctl‘;

将备份及监听文件和密码文件全部复制到fdb2上(fdb1)

scp -r /opt/oracle/dbackup/* fdb2:/opt/oracle/dbackup

scp -r $ORACLE_HOME/network/admin/* fdb2:$ORACLE_HOME/network/admin/

scp -r $ORACLE_HOME/dbs/* fdb2:$ORACLE_HOME/dbs/

在fdb2上执行如下对数据库进行恢复(fdb2)

RMAN> startup nomount;

RMAN> restore spfile to pfile ‘/tmp/fengdb.pfile‘ from ‘/opt/oracle/dbackup/spfile_rmrioont_20161019.bak‘;

RMAN> shutdown immediate;

然后修改/etc/fengdb.pfile成如下的红色部分

*.db_unique_name=‘fdb2‘

*.fal_client=‘fdb2‘

*.fal_server=‘fdb1‘

*.log_archive_config=‘dg_config=(fdb2,fdb1)‘

*.log_archive_dest_1=‘location=/opt/oracle/flash_recovery_area/fengdb/archivelog valid_for=(all_logfiles,all_roles)  db_unique_name=fdb2‘

*.log_archive_dest_2=‘service=fdb1 async  valid_for=(online_logfiles,primary_role)  db_unique_name=fdb1‘

*.log_archive_dest_state_1=‘ENABLE‘

*.log_archive_dest_state_2=‘ENABLE‘

备库复制控制文件(fdb2)

cp /opt/oracle/dbackup/standby.ctl /opt/oracle/oradata/fengdb/control01.ctl

cp /opt/oracle/dbackup/standby.ctl /opt/oracle/oradata/fengdb/control02.ctl

cp /opt/oracle/dbackup/standby.ctl /opt/oracle/oradata/fengdb/control03.ctl

启动至mount状态进行数据的恢复

RMAN> startup mount;
RMAN> restore database;

启动备库应用日志

SQL> alter database recover managed standby database using current logfile disconnect from session;

创建参数文件

SQL> create spfile from pfile=‘/tmp/fengdb.pfile‘;

注意:Oracle 10G与11G的区别:

10G备库只能启动到mount状态,而11G可以启动到open read only.

检查日志是否同步(fdb1,fdb2)

select sequence#,applied from v$archived_log;

也可以试着切换下日志

//切换日志
alter system switch logfile;
select sequence#,applied from v$archived_log;

在主库:(fdb1)

select dest_name,status,error from v$archive_dest;
alter system set log_archive_dest_state_2= enable;

查询角色(fdb1,fdb2)

select open_mode,database_role from v$database;

如果在备库上

SQL> select sequence#,applied from v$archived_log;

no rows selected

而且监听都是正常的,则有可能就是密码没复制过来

保持主库密码和备库密码一致

复制密码文件(fdb1)

scp $ORACLE_HOME/dbs/orapw$ORACLE_SID fdb2:$ORACLE_HOME/dbs/orapw$ORACLE_SID
时间: 2024-10-11 07:08:13

Oracle 10G DataGuard搭建的相关文章

Oracle 10g DataGuard手记之基础配置

DataGuard为企业数据的高可用性,数据安全以及灾难恢复提供支持,一般由一个primary db与几个物理或逻辑standby db组成一个DataGuard配置. 系统环境 操作系统为windows server 2003 r2 enterprise x64 edition service pack 2,database为oracle 10g 10.2.0.4 enterprise x64 edition.服务器均为AMD64架构,主机RAID5本地硬盘加RAID1光纤盘阵. primar

Oracle 10gR2 Dataguard搭建(非duplicate方式)

我的实验环境:源生产库(主库):IP地址:192.168.1.30Oracle 10.2.0.5 单实例 新DG库(备库):IP地址:192.168.1.31Oracle 10.2.0.5 单实例 1.源生产库开启归档 2.rman备份源生产库 3.修改源生产库参数 4.配置tnsnames.ora 5.同步密码文件 6.配置pfile文件 7.创建备库控制文件 8.还原备库 9.开启日志应用 10.switchover测试 11.创建还原点,激活备库测试 12.failover测试 1.源生产

Oracle 11g DataGuard搭建(一) - 单节点到单节点

(一)DataGuard概要 DataGuard中文称为”数据卫士“,提供了数据库高可用性.数据保护和灾难恢复的功能.DataGuard通过建立primary数据库和standby数据库来确立参照关系,DataGuard将主库(primary)的redo日志传递给备库(standby),然后在备库中应用redo进行同步. 备库又分为2种类型:物理备库和逻辑备库 物理standby是通过块拷贝方式同步,通过接受并应用primary数据库的redo log,以介质恢复的方式同步.在物理备库中,数据是

CentOS 5.11下Oracle 11G R2 Dataguard搭建

Datagard算是Oracle企业版的一种容灾方案,在企业中广泛应用,我就将搭建过程记录下来以作备用. 主机名    数据库版本    实例名    IP db1    Oracle 11G R2    member    172.16.1.250 db2    Oracle 11G R2    member    172.16.1.251 默认情况下以上都已经安装好了Oracle数据库,但是只在db1上建立了数据库和监听,db2只安装Oracle软件不建库,不建监听. 目录: 打开强制归档日

oracle 10g 物理Dataguard 日常操作管理(一)

最近发现MDT推出去的系统的有不同问题,其问题就不说了,主要是策略权限被域继承了.比如我们手动安装的很多东东都是未配置壮态,推的就默认为安全壮态了,今天细找了一下,原来把这个关了就可以了. oracle 10g 物理Dataguard 日常操作管理(一)

Oracle 10g 物理Dataguard日常操作维护(二)

3.3进程日志的监控操作 3.3.1 查看备库进程状态 SQL>select process,client_process,sequence#,status from v$managed_standby PROCESS   CLIENT_P  SEQUENCE#    STATUS ---------       --------     ---------- -      ----------- ARCH      ARCH            153       CLOSING ARCH 

ORACLE 11G 之DATAGUARD搭建逻辑standby

Oracle Data Guard逻辑备库是利用主库的一个备份首先建立一个物理备库,然后再将其转换为逻辑备库.这之后主库将日志传递到备库,备库利用logminer从主库的日志中解析出主库所执行过的SQL,在备库上重新执行一遍,从而保证与主库的数据在逻辑上保持一致.与物理备库相对应的是,物理备库使用的是redo apply,逻辑备库使用的是sql apply.因此逻辑备库仅仅保证数据与主库是在逻辑上是一致的,从而逻辑备库可以处于open状态下并进行相应的DML操作. 在转换physical备库到l

ORACLE 11G DataGuard的一些高级管理案例研究

搭建完了ORACLE 11G dataguard后,也做了角色切换的实验,有switchover已经failover,感觉受益颇多,而后继续研究了下dataguard的一些高级管理功能,所谓冰山一角,ORACLE果然博大精深,总结记录如下:1,ORACLE 11G dataguard的高级管理1.1.READ ONLY/WRITE模式打开物理STANDBY一般standby都是可以设置为mount状态的,于物理standby 可以有效分担primary 数据库压力,提升资源利用,实际上说的就是这

Redhat 5.4 + ASM + RAW+ Oracle 10g RAC 安装文档

基于Redhat 5 和redhat 4 的RAC 区别在对raw的处理上. 之前做的是redhat 4.7 的 RAC 实验. 准备做一个Redhat 5.4 的环境. RAC 的一些理论东西: http://blog.csdn.net/tianlesoftware/archive/2010/02/27/5331067.aspx RAW+ASM+ REDHAT 4.7 RAC 文档 http://blog.csdn.net/tianlesoftware/archive/2010/02/27/5