欢迎投稿

今日深度:

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

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


[Oracle] Data Guard系列(4) - 在不停主库的情况下创建物理备库
 
今天需要对一个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,可以通过以下语句查询:
[sql] 
SYS@JKKA>select log_mode,force_logging from v$database;  
  
LOG_MODE     FOR  
------------ ---  
ARCHIVELOG   NO  
从上面我们发现主库已经开启了归档,但没有开启force logging,可以通过以下语句开启:
[sql] 
SYS@JKKA>alter database force logging;  
  
Database altered.  
 
2)创建主库密码文件
主备库间需要通过密码文件互相通讯,我们先在主库端创建密码文件,之后再把它同步到备库中:
[plain] 
$ orapwd file=$ORACLE_HOME/dbs/orapwjkka  
确认参数remote_login_passwordfile为EXCLUSIVE(默认值):
[sql] 
SYS@JKKA>show parameter remote_login_passwordfile  
  
NAME                                 TYPE        VALUE  
------------------------------------ ----------- ------------------------------  
remote_login_passwordfile            string      EXCLUSIVE  
通过v$pwfile_users再次确认sys用户在密码文件中:
[sql] 
SYS@JKKA>select * from v$pwfile_users;  
  
USERNAME                       SYSDB SYSOP SYSAS  
------------------------------ ----- ----- -----  
SYS                            TRUE  TRUE  FALSE  
 
3)配置主库参数
首先,查看主库的db_name和db_unique_name:
[sql] 
SYS@JKKA>show parameter db_name  
  
NAME                                 TYPE        VALUE  
------------------------------------ ----------- ------------------------------  
db_name                              string      jkka  
SYS@JKKA>show parameter db_unique_name  
  
NAME                                 TYPE        VALUE  
------------------------------------ ----------- ------------------------------  
db_unique_name                       string      jkka  
接着,修改log_acchive_config参数,在dg_config属性分别写上主备库的db_unique_name:
[sql] 
SYS@JKKA>alter system set log_archive_config='DG_CONFIG=(jkka,jkka2)';  
  
System altered.  
配置log_archive_dest_1写入本地目录:
[sql] 
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:
[sql] 
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.  
下面这些参数是可选的,只有当主库切换成备库时有效,但强烈建议配置,否则以后主备库切换会失败。
[sql] 
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
[sql] 
SYS@JKKA>create pfile from spfile;  
  
File created.  
 
2.启动备库实例
 
1)安装数据库软件
安装Oracle软件这里就不再累述,要注意的一点是备库的版本要和主库的一样。(注意:这里的版本包括小版本也要一样,比如主库是11.2.0.1,备库时11.2.0.3就不行)
 
2)创建备库的参数文件
备库的参数文件可以根据主库的参数文件适当修改即可,在之前我们已经生成了主库的pfile,所有我们只要把它拷贝到备库,然后修改以下参数:
[plain] 
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状态
[sql] 
$ export ORACLE_SID=jkka  
$ sqlplus / as sysdba  
SQL>startup nomount  
 
4. 主备库的网络设置
 
1)主库的监听器设置
[plain] 
LISTENER =  
  (DESCRIPTION_LIST =  
    (DESCRIPTION =  
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))  
      (ADDRESS = (PROTOCOL = TCP)(HOST = lx32)(PORT = 1521))  
    )  
  )  
2)备库的监听器设置
[plain] 
LISTENER =  
  (DESCRIPTION_LIST =  
    (DESCRIPTION =  
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))  
      (ADDRESS = (PROTOCOL = TCP)(HOST = lx201)(PORT = 1521))  
    )  
  )  
3)主备库tnsnames.ora的设置
[plain] 
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用户远程登录来测试:
[plain] 
主库:  
$ sqlplus sys@jkkasta as sysdba  
备库:  
$ sqlplus sys@jkkapri as sysdba  
 
4.复制主库至备库
 
我们可以通过rman的duplicate命令,在主库不停机的情况下,创建备库。这里有个前提条件,就是备库的目录结构和主库一模一样。
 
1)创建主库备份
备份全库和归档日志:
[sql] 
$ 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状态
[sql] 
$ rman target sys/***@jkkapri AUXILIARY /  
RMAN> duplicate target database for standby dorecover nofilenamecheck;  
上面的语句执行完毕后,会在相应目录下生成数据文件、日志文件、audit,数据库处于mount状态。
有可能会出现下面的错误:
[sql] 
ORACLE error from auxiliary database: ORA-19527: physical standby redo log must be renamed  
ORA-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)步。
[sql] 
<pre></pre>  
<pre></pre>  
<pre></pre>  
3)在主备库上分别创建standby redo log
Oracle规定standby redo log
[sql] 
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] 
SQL>create spfile from pfile;  
  
File created.  
  
SQL>shutdown immediate  
SQL>startup   
5)重建备库的online redo log
[sql] 
<span style="font-weight: normal;">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.</span>  
 
5. 备库启动redo apply
 
因为之前我们把log_archive_dest_state_2设为defer,现在需要在主备库中把它设为enable:
[sql] 
SYS@JKKA>alter system set log_archive_dest_state_2=enable;  
  
System altered.  
 
现在一切都已准备就绪,可以在备库启动日志应用:
[sql] 
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;  
  
Database altered.  
 
下面验证主备库间是否可以同步,首先查看备库当前的归档日志:
[sql] 
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:
[sql] 
SYS@JKKA>select max(sequence#) from v$archived_log;  
  
MAX(SEQUENCE#)  
--------------  
           504  
我们在主库做一次日志切换,此时主库的最大归档日志为505.
[sql] 
SYS@JKKA>ALTER SYSTEM SWITCH LOGFILE;  
  
System altered.  
这时再看备库的归档日志,如果505已经从主库成功拷贝至备库,说明主备库同步正常。
[sql] 
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  
 

www.htsjk.Com true http://www.htsjk.com/oracle/20989.html NewsArticle [Oracle] Data Guard系列(4) - 在不停主库的情况下创建物理备库 [Oracle] Data Guard系列(4) - 在不停主库的情况下创建物理备库 今天需要对一个24*7的生产库创建一个DG的物理备库,要求主库...
相关文章
    暂无相关文章
评论暂时关闭