一、环境
主库:
备库:
二、安装Oracle软体
只装数据库软件,不建库,具体安装过程,请参考:
http://cncto.blog.51cto.com/235831/887977
在主机和备机上的/etc/hosts中加入以下内容:
- 192.168.10.48 sms01. domain.com sms01
- 192.168.10.50 sms02.domain.com sms02
- 10.0.0.101 smsdg01.domain.com smsdg01
- 10.0.0.102 smsdg02.domain.com smsdg02
三、配置主库SMS01
1、主库运行dbca创建数据库(安装过程中需要注意:先关掉flash recovery,启用archive,配置日志归档路径/data/SMS/archive_log/),数据库SID:SMS(如果主库已经安装就无需此步)
2、用sqlplus登录数据库:
- [oracle@sms01 ~]$ sqlplus /nolog
- SQL*Plus: Release 11.2.0.1.0 Production on Sun Mar 18 18:01:11 2012
- Copyright (c) 1982, 2009, Oracle. All rights reserved.
- SQL> conn / as sysdba
- Connected.
- SQL>
3、将主库设置为force logging模式
- SQL> ALTER DATABASE FORCE LOGGING;
- database altered.
4、创建一个密码文件,如果数据库是用dbca创建的则会在$ORACLE_HOME/dbs/下自动创建一个叫orapwSID的一个密码文件。否则可以用orapwd命令创建一个。
5、配置Standby Redo Log。创建组数至少要比主库的online redo log组数多一个。
- SQL> select group#,bytes from v$log;
- GROUP# BYTES
- ---------- ----------
- 1 52428800
- 2 52428800
- 3 52428800
至少再创建4组Standby Redo Log:
- SQL>ALTER DATABASE ADD STANDBY LOGFILE GROUP 4 ('/data/SMS/DB/SMS/stdbyredo01.log') SIZE 52428800;
- Database altered.
- SQL>ALTER DATABASE ADD STANDBY LOGFILE GROUP 5 ('/data/SMS/DB/SMS/stdbyredo02.log') SIZE 52428800;
- Database altered.
- SQL>ALTER DATABASE ADD STANDBY LOGFILE GROUP 6 ('/data/SMS/DB/SMS/stdbyredo03.log') SIZE 52428800;
- Database altered.
- SQL>ALTER DATABASE ADD STANDBY LOGFILE GROUP 7 ('/data/SMS/DB/SMS/stdbyredo04.log') SIZE 52428800;
- Database altered.
验证创建结果:
- SQL> select group#,thread#,sequence#,archived,status from V$standby_log;
- GROUP# THREAD# SEQUENCE# ARC STATUS
- ---------- ---------- ---------- --- ----------
- 4 0 0 YES UNASSIGNED
- 5 0 0 YES UNASSIGNED
- 6 0 0 YES UNASSIGNED
- 7 0 0 YES UNASSIGNED
$$删除日志组命令:
- SQL> alter database drop standby logfile group 4;
$$给指定组添加成员命令:
- SQL> ALTER DATABASE ADD STANDBY LOGFILE MEMBER '/data/SMS/DB/SMS/stdbyredo04_1.log' TO GROUP 7;
$$删除组中成员命令:
- SQL> ALTER DATABASE DROP STANDBY LOGFILE MEMBER '/data/SMS/DB/SMS/stdbyredo04_1.log';
- Database altered.
- SQL> host rm -f /data/SMS/DB/SMS/stdbyredo04_1.log
6、检查数据库归档状态
- SQL> archive log list;
- Database log mode Archive Mode
- Automatic archival Enabled
- Archive destination /data/SMS/archive_log/
- Oldest online log sequence 5
- Next log sequence to archive 7
- Current log sequence 7
如果不处于归档状态则执行:
- SQL> SHUTDOWN IMMEDIATE;
- SQL> STARTUP MOUNT;
- SQL> ALTER DATABASE ARCHIVELOG;
- SQL> ALTER DATABASE OPEN;
7、创建备库的控制文件(创建后数据库不能做结构性的改动)
- SQL> alter database create standby controlfile as '/data/SMS/DB/SMS/stdby.ctl';
8、创建pfile以便修改配置参数
- SQL> create pfile='/data/SMS/DB/SMS/pfile' from spfile;
- File created.
9、关掉数据库编辑pfile
- SQL>shutdown immediate;
10、$vim /data/SMS/DB/SMS/pfile
- ##添加以下内容
- DB_UNIQUE_NAME=sms01
- LOG_ARCHIVE_CONFIG='DG_CONFIG=(sms01,sms02)'
- LOG_ARCHIVE_DEST_2=
- 'SERVICE=sms02 LGWR ASYNC
- VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
- DB_UNIQUE_NAME=sms02'
- LOG_ARCHIVE_DEST_STATE_1=ENABLE
- LOG_ARCHIVE_DEST_STATE_2=ENABLE
- LOG_ARCHIVE_MAX_PROCESSES=30
- FAL_SERVER=sms02
- FAL_CLIENT=sms01
- DB_FILE_NAME_CONVERT='sms01','sms02'
- STANDBY_FILE_MANAGEMENT=AUTO
11、进入sqlplus创建pfile(NOMOUNT状态)
- SQL> create spfile from pfile='/data/SMS/DB/SMS/pfile';
- File created.
12、利用netca工具创建tnsnames.ora和listener.ora,也可手动创建,内容如下:
$cat /data/oracle/DB/oracle/network/admin/listener.ora
- LISTENER =
- (DESCRIPTION_LIST =
- (DESCRIPTION =
- (ADDRESS = (PROTOCOL = TCP)(HOST = sms01.domain.com)(PORT = 1521))
- )
- )
- ADR_BASE_LISTENER = /data/oracle/DB
- SID_LIST_LISTENER =
- (SID_LIST =
- (SID_DESC =
- (SID_NAME = SMS)
- (ORACLE_HOME = /data/oracle/DB/oracle)
- (PROGRAM = extproc)
- )
- (SID_DESC =
- (GLOBAL_DBNAME = SMS.DH)
- (SID_NAME = SMS)
- (ORACLE_HOME = /data/oracle/DB/oracle)
- )
- )
$cat /data/oracle/DB/oracle/network/admin/tnsnames.ora
- SMS =
- (DESCRIPTION =
- (ADDRESS = (PROTOCOL = TCP)(HOST = sms01.domain.com)(PORT = 1521))
- (CONNECT_DATA =
- (SERVER = DEDICATED)
- (SERVICE_NAME = SMS.DH)
- )
- )
- sms01 =
- (DESCRIPTION =
- (ADDRESS = (PROTOCOL = TCP)(HOST = smsdg01.domain.com)(PORT = 1521))
- (CONNECT_DATA =
- (SERVER = DEDICATED)
- (SERVICE_NAME = SMS.DH)
- )
- )
- sms02 =
- (DESCRIPTION =
- (ADDRESS = (PROTOCOL = TCP)(HOST = smsdg02.domain.com)(PORT = 1521))
- (CONNECT_DATA =
- (SERVER = DEDICATED)
- (SERVICE_NAME = SMS.DH)
- )
- )
13、复制备份文件到备库(注意检查复制过去的文件的属主及群组)
要复制的清单:
归档日志目录/admin目录/数据库存储目录(包括数据文件,控制文件,redo日志,standby redo日志等)/监听文件/orapwSID密码文件,详细如下:
四、配置备库SMS02
- DB_UNIQUE_NAME=sms02
- LOG_ARCHIVE_CONFIG='DG_CONFIG=(sms01,sms02)'
- LOG_ARCHIVE_DEST_2=
- 'SERVICE=sms01 LGWR ASYNC
- VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE)
- DB_UNIQUE_NAME=sms01'
- LOG_ARCHIVE_DEST_STATE_1=ENABLE
- LOG_ARCHIVE_DEST_STATE_2=ENABLE
- LOG_ARCHIVE_MAX_PROCESSES=30
- FAL_SERVER=sms01
- FAL_CLIENT=sms02
- DB_FILE_NAME_CONVERT='sms01','sms02'
- STANDBY_FILE_MANAGEMENT=AUTO
- [oracle@sms02 ~]$ sqlplus /nolog
- SQL*Plus: Release 11.2.0.1.0 Production on Wed Jun 6 11:17:31 2012
- Copyright (c) 1982, 2009, Oracle. All rights reserved.
- SQL> conn / as sysdba;
- Connected to an idle instance.
- SQL> create spfile from pfile='/data/SMS/DB/SMS/pfile';
- File created.
五、DG测试
- $sqlplus / as sysdba;
- SQL>startup
- $ sqlplus /nolog
- SQL> conn / as sysdba;
- SQL> startup mount
- SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;
备注:以上是挂载数据库,并启用redo应用,此为物理standby的redo应用模式
- SQL> startup mount
- SQL> alter database open read only
- SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT FROM SESSION;
3、 在主库上做一次日志切换
- SQL>ALTER SYSTEM SWITCH LOGFILE;
分别在主库和备库上做切换前后的下列查询,检查归档日志从主库传送到备库的情况:
- SQL> SELECT SEQUENCE#,APPLIED FROM V$ARCHIVED_LOG ORDER BY SEQUENCE#;
- 备注:这个可以结合以下的日志动态显示对比查看:
- $tail -f /data/oracle/DB/diag/rdbms/sms01/SMS/trace/alert_SMS.log
4、在主库上建表插入数据并在备库查询:
- SQL>create table smstest(id integer,name char(10));
- SQL>insert into smstest values(1,'sms01');
- SQL>commit;
- ##如果standby模式为read-only模式下的实时redo应用模式,在主库commit后,在备库直接查询即可:
- SQL>select * from smstest;
如果Standby模式为redo应用模式,需做如下操作后才可查询:
- ##测试时,需要在主库上做一次日志归档,将日志传送给standby库:
- SQL>ALTER SYSTEM ARCHIVE LOG CURRENT;
- ##在备库上取消掉redo应用,因为在redo应用模式下不能打开数据库:
- SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE CANCEL;
- SQL>ALTER DATABASE OPEN;
- SQL>SELECT * FROM smstest;
测试成功!
- ##再次切换为备库的redo apply状态(只限redo应用模式)
- SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;
六、主备库互相切换
七、维护
1、开机顺序,先备库的listener再启动备库。再启动主库的listener,再启动主库。
2、关机顺序,先关闭主库,再关闭备库
- SQL>select to_char(start_time,'dd-mon-rr hh24:mi:ss') start_time,item,sofar from V$recovery_progress where item in ('Active Apply Rate', 'Average Apply Rate','Redo Applied');
本文出自 “鼠标爱上键盘” 博客,转载请与作者联系!