[Oracle] Data Guard 系列(4) - 在不停主库的情况下创建物理备库

来源:互联网 发布:qos发展 知乎 编辑:程序博客网 时间:2024/04/28 10:27

今天需要对一个24*7的生产库创建一个DG的物理备库,要求主库不能停机,一开始以为不可能,后来查了下文档,原来通过rman的duplicate命令可以实现在线创建物理备库。

主备库的信息如下:

角色      db_name      db_unique_name      主机           网络连接字符串

主库       jkka                jkka                                lx32            jkkapri

备库       jkka                jkka2                              lx201         jkkasta


1.主库的准备工作


1)确认主库已开启归档和force logging
DG要求主库一定要开启归档和force logging,可以通过以下语句查询:
SYS@JKKA>select log_mode,force_logging from v$database;LOG_MODE     FOR------------ ---ARCHIVELOG   NO
从上面我们发现主库已经开启了归档,但没有开启force logging,可以通过以下语句开启:
SYS@JKKA>alter database force logging;Database altered.

2)创建主库密码文件
主备库间需要通过密码文件互相通讯,我们先在主库端创建密码文件,之后再把它同步到备库中:
$ orapwd file=$ORACLE_HOME/dbs/orapwjkka
确认参数remote_login_passwordfile为EXCLUSIVE(默认值):
SYS@JKKA>show parameter remote_login_passwordfileNAME                                 TYPE        VALUE------------------------------------ ----------- ------------------------------remote_login_passwordfile            string      EXCLUSIVE
通过v$pwfile_users再次确认sys用户在密码文件中:
SYS@JKKA>select * from v$pwfile_users;USERNAME                       SYSDB SYSOP SYSAS------------------------------ ----- ----- -----SYS                            TRUE  TRUE  FALSE

3)配置主库参数
首先,查看主库的db_name和db_unique_name:
SYS@JKKA>show parameter db_nameNAME                                 TYPE        VALUE------------------------------------ ----------- ------------------------------db_name                              string      jkkaSYS@JKKA>show parameter db_unique_nameNAME                                 TYPE        VALUE------------------------------------ ----------- ------------------------------db_unique_name                       string      jkka
接着,修改log_acchive_config参数,在dg_config属性分别写上主备库的db_unique_name:
SYS@JKKA>alter system set log_archive_config='DG_CONFIG=(jkka,jkka2)';System altered.
配置log_archive_dest_1写入本地目录:
SYS@JKKA>alter system set log_archive_dest_1='location=/data/oradata/jkka/archivelog  valid_for=(all_logfiles,all_roles) db_unique_name=jkka';System altered.SYS@JKKA>alter system set log_archive_dest_state_1=enable;System altered.
配置log_archive_dest_2写入远程目录,因为这时候还没有备库,所有这里我们暂时把log_archive_dest_state_2设为defer:
SYS@JKKA>alter system set log_archive_dest_state_2=defer;System altered.SYS@JKKA>alter system set log_archive_dest_2='service=jkkasta ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) db_unique_name=jkka2';System altered.
下面这些参数是可选的,只有当主库切换成备库时有效,但强烈建议配置,否则以后主备库切换会失败。
SYS@JKKA>alter system set fal_server=jkka2;System altered.SYS@JKKA>alter system set fal_client=jkka;System altered.SYS@JKKA>alter system set standby_file_management=auto;System altered.
最后创建pfile
SYS@JKKA>create pfile from spfile;File created.

2.启动备库实例


1)安装数据库软件
安装Oracle软件这里就不再累述,要注意的一点是备库的版本要和主库的一样。(注意:这里的版本包括小版本也要一样,比如主库是11.2.0.1,备库时11.2.0.3就不行)

2)创建备库的参数文件
备库的参数文件可以根据主库的参数文件适当修改即可,在之前我们已经生成了主库的pfile,所有我们只要把它拷贝到备库,然后修改以下参数:
db_unique_name='jkka2'fal_client='JKKA2'fal_server='JKKA'log_archive_dest_1='location=/data/oradata/jkka/archivelog  valid_for=(all_logfiles,all_roles) db_unique_name=jkka2'log_archive_dest_2='service=jkkapri ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) db_unique_name=jkka'

3)拷贝主库的密码文件至备库

4)在备库上创建和主库一模一样的目录结构
需要创建的目录有日志文件、控制文件、数据文件、归档日志、audit目录等。

5)启动备库至nomount状态
$ export ORACLE_SID=jkka$ sqlplus / as sysdbaSQL>startup nomount

4. 主备库的网络设置


1)主库的监听器设置
LISTENER =  (DESCRIPTION_LIST =    (DESCRIPTION =      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))      (ADDRESS = (PROTOCOL = TCP)(HOST = lx32)(PORT = 1521))    )  )
2)备库的监听器设置
LISTENER =  (DESCRIPTION_LIST =    (DESCRIPTION =      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))      (ADDRESS = (PROTOCOL = TCP)(HOST = lx201)(PORT = 1521))    )  )
3)主备库tnsnames.ora的设置
jkkasta =  (DESCRIPTION =    (ADDRESS_LIST =      (ADDRESS = (PROTOCOL = TCP)(HOST =lx201)(PORT = 1521))    )    (CONNECT_DATA =      (sid = jkka)    )  )jkkapri =  (DESCRIPTION =    (ADDRESS = (PROTOCOL = TCP)(HOST =lx32)(PORT = 1521))    (CONNECT_DATA =      (SERVER = DEDICATED)      (sid =jkka)    )  )
4)测试主备库是否互通
因为之前在主备库上都已经有了密码文件,所有可以使用sys用户远程登录来测试:
主库:$ sqlplus sys@jkkasta as sysdba备库:$ sqlplus sys@jkkapri as sysdba

4.复制主库至备库


我们可以通过rman的duplicate命令,在主库不停机的情况下,创建备库。这里有个前提条件,就是备库的目录结构和主库一模一样。

1)创建主库备份
备份全库和归档日志:
$ rman target /RMAN> backup full format='/home/oracle/backup/ora_bak/data/db_jkka_%U' database include current controlfile for standby plus archivelog format='/home/oracle/backup/ora_bak/data/arc_jkka_%U';
备份成功后,手动把备份文件拷贝至备库主机(scp,ftp等)。

2)在备库执行恢复
在执行恢复之前,一定要保证三点:1,备份文件在备库的目录一定要和主库的一样;2,备库存放数据文件等相应的目录都已存在。3,备库处于nomount状态
$ rman target sys/***@jkkapri AUXILIARY /RMAN> duplicate target database for standby dorecover nofilenamecheck;
上面的语句执行完毕后,会在相应目录下生成数据文件、日志文件、audit,数据库处于mount状态。
有可能会出现下面的错误:
ORACLE error from auxiliary database: ORA-19527: physical standby redo log must be renamedORA-00312: online log 1 thread 1: '/data/oradata/jkka/data/redoa1.log'RMAN-05535: WARNING: All redo log files were not defined properly.
这是因为oracle为了加快备库与主库switchover的速度,从10.2开始增加了一个增强的功能,就是当MRP启动时会去清理备库上online redo log。如果不考虑switchover(备库上不创建online reod log),那么可以忽略这个错误,因为这个错只是一个提示性的信息,不会影响备库的MRP的工作。如果考虑switchover,就要在备库上创建online reod log,需要数据库在打开的情况下,具体见第5)步。

3)在主备库上分别创建standby redo log
Oracle规定standby redo log的大小不得小于online redo log
SYS@JKKA>ALTER DATABASE ADD STANDBY LOGFILE GROUP 10 ('/data/oradata/jkka/data/standby_redo10.log') size 100M;Database altered.SYS@JKKA>ALTER DATABASE ADD STANDBY LOGFILE GROUP 11 ('/data/oradata/jkka/data/standby_redo11.log') size 100M;Database altered.SYS@JKKA>ALTER DATABASE ADD STANDBY LOGFILE GROUP 12 ('/data/oradata/jkka/data/standby_redo12.log') size 100M;Database altered.SYS@JKKA>ALTER DATABASE ADD STANDBY LOGFILE GROUP 13 ('/data/oradata/jkka/data/standby_redo13.log') size 100M;Database altered.
4)创建备库的spfile,重启备库至mount或open状态
从11g开始,物理备库既可以启动至moutn,也可以启动至open
SQL>create spfile from pfile;File created.SQL>shutdown immediateSQL>startup 
5)重建备库的online redo log
SYS@jkka> alter system set standby_file_management=manual;System altered.SYS@jkka> alter system set LOG_FILE_NAME_CONVERT='/data/oradata/jkka/data/','/data/oradata/jkka/data/' scope=spfile;System altered.shutdown immediate;startup;SYS@jkka> alter database clear logfile group 1;Database altered.SYS@jkka> alter database clear logfile group 2;Database altered.SYS@jkka> alter database clear logfile group 3;Database altered.SYS@jkka> alter system reset LOG_FILE_NAME_CONVERT;System altered.shutdown immediate;startup;SYS@jkka> alter system set standby_file_management=auto;System altered.

5. 备库启动redo apply

因为之前我们把log_archive_dest_state_2设为defer,现在需要在主备库中把它设为enable:
SYS@JKKA>alter system set log_archive_dest_state_2=enable;System altered.

现在一切都已准备就绪,可以在备库启动日志应用:
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;Database altered.

下面验证主备库间是否可以同步,首先查看备库当前的归档日志:
SQL>SELECT SEQUENCE#, FIRST_TIME, NEXT_TIME FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#; SEQUENCE# FIRST_TIME          NEXT_TIME---------- ------------------- -------------------       504 2013-08-22 14:41:54 2013-08-22 20:32:39
从上面我们可以看出备库当前最大的归档日志为504。
然后再查看主库当前最大的归档日志也是504:
SYS@JKKA>select max(sequence#) from v$archived_log;MAX(SEQUENCE#)--------------           504
我们在主库做一次日志切换,此时主库的最大归档日志为505.
SYS@JKKA>ALTER SYSTEM SWITCH LOGFILE;System altered.
这时再看备库的归档日志,如果505已经从主库成功拷贝至备库,说明主备库同步正常。
SQL>SELECT SEQUENCE#, FIRST_TIME, NEXT_TIME FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#; SEQUENCE# FIRST_TIME          NEXT_TIME---------- ------------------- -------------------       504 2013-08-22 14:41:54 2013-08-22 20:32:39       505 2013-08-22 20:32:39 2013-08-22 20:35:41

《[Oracle] Data Guard 系列(1) - 三种保护模式》

《[Oracle] Data Guard 系列(2) - 日志传输》

《[Oracle] Data Guard 系列(3) - 日志应用》

《[Oracle] Data Guard 系列(4) - 在不停主库的情况下创建物理备库》

《[Oracle] Data Guard 系列(5) - 创建逻辑备库》

《[Oracle] Data Guard 系列(6) - 角色转换》