dataguard
1. 安装oracle,创建primary数据库
2. 设置primary库force logging.
PRIMARY>alter database force logging;
Database altered.
3. 创建密码文件
[oracle@PRIMARY]orapwd file=orapwprimary password=xxxxxxx;
4. 修改有关data guard的参数
PRIMARY> show parameter log_archive_config
PRIMARY> alter system set log_archive_config='DG_CONFIG=(zxdb,zxdbdg1)';
System altered.
PRIMARY>alter system set log_archive_dest_1='LOCATION=/u01/app/oracle/oradata/zxdb/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=zxdb';
System altered.
5. 添加standby log group
PRIMARY>alter database add standby logfile group 4('/u01/app/oracle/oradata/zxdb/standbylog/group_4_1.log','/u01/app/oracle/oradata/zxdb/standbylog/group_4_2.log') size 30m;
Database altered.
PRIMARY>alter database add standby logfile group 5('/u01/app/oracle/oradata/zxdb/standbylog/group_5_1.log','/u01/app/oracle/oradata/zxdb/standbylog/group_5_2.log') size 30m;
Database altered.
创建成功后,在v$standby_log可以看到新加入的两个standby logfile的group, 在v$log里查询可以看到新添加进去的4个standby logfile。
6. 修改参数
fal_server zxdbdg
fal_client zxdb
standby_file_management auto
log_archive_dest_state_2 enable
log_archive_max_processes
7. 创建standby控制文件
PRIMARY> alter database create standby controlfile as '/u01/app/oracle/standby.ctl';
8. 导出spfile为pfile
PRIMARY> create pfile='/u01/app/oracle/init.ora' from spfile;
9. 复制数据库,可以物理拷贝,也可以用RMAN。
10. scp拷贝pfile和standby controlfile到备考机器
scp /u01/app/oracle/standby.ctl oracle:dg /u01/app/oracle/oradata/zxdb/controlfile/control1.ctl
scp /u01/app/oracle/init.ora oracle:dg /u01/app/oracle/product/10.2.0/db_1/dbs/initzxdb.ora
11. 修改pfile
db_unique_name zxdbdg
control_files /u01/app/oracle/oradata/zxdb/controlfile/standby.ctl
log_archive_dest_1 LOCATION=/u01/app/oracle/oradata/zxdb/archivelog VALID_FOR=(ALL_LOGFILES,ALL_ROLES) DB_UNIQUE_NAME=zxdbdg
log_archive_dest_2 SERVICE=zxdb LGWR ASYNC VALID_FOR=(ONLINE_LOGFILES,PRIMARY_ROLE) DB_UNIQUE_NAME=zxdb
fal_server zxdb
fal_client zxdbdg
12. 在备库上pfile为spfile
STANDBY> create spfile='/u01/app/oracle/product/10.2.0/db_1/dbs/spfilezxdb.ora' from pfile='/u01/app/oracle/product/10.2.0/db_1/dbs/initzxdb.ora'
13. 在主机上建立tns service zxdb和zxdbdg这里是上面fal指定的
zxdb =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.16.10.129)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = zxdb)
)
)
zxdbdg =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.16.10.130)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = zxdb)
)
)
14 在备课上配置同上的tnsname
zxdb =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.16.10.129)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = zxdb)
)
)
zxdbdg =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 172.16.10.130)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = zxdb)
)
)
15. 启动备库
STANDBY> start mount
16. 应用redo
STANDBY> recover managed standby database
这里注意,这个事handle的。所以关掉session的话,会停止住。
一般我们都是用disconnect来解决这个问题
STANDBY> recover managed standby database disconnect from session
测试dg
在主库上insert data并且commit
ID NAME
--------------------------------------- ----------
1 test1
2 test2
3 test3
4 test4
查看主库v$archived_log
PRIMARY> select RECID, STAMP, NAME, DEST_ID, SEQUENCE#, STANDBY_DEST, ARCHIVED, APPLIED from v$archived_log;
11 712946684 /u01/app/oracle/oradata/zxdb/archivelog/1_11_712892825.dbf 1 11 NO YES NO
12 712946692 zxdbdg1 2 11 YES YES YES
13 712948030 /u01/app/oracle/oradata/zxdb/archivelog/1_12_712892825.dbf 1 12 NO YES NO
14 712948031 zxdbdg1 2 12 YES YES YES
在备库上查看v$archived_log
STANDBY> create table test.testobject as select * from dba_tables;
STANDBY> alter database open read only;
SQL> select RECID, STAMP, NAME, DEST_ID, SEQUENCE#, STANDBY_DEST, ARCHIVED, APPLIED from v$archived_log;
RECID STAMP NAME DEST_ID SEQUENCE# STANDBY_DEST ARCHIVED APPLIED
---------- ---------- -------------------------------------------------------------------------------- ---------- ---------- ------------ -------- -------
1 712946690 /u01/app/oracle/oradata/zxdb/archivelog/1_11_712892825.dbf 1 11 NO YES YES
2 712948028 /u01/app/oracle/oradata/zxdb/archivelog/1_12_712892825.dbf 2 12 NO YES YES
STANDBY> select RECID, STAMP, NAME, DEST_ID, SEQUENCE#, STANDBY_DEST, ARCHIVED, APPLIED from v$archived_log;
ID NAME
--------------------------------------- ----------
1 test1
2 test2
3 test3
4 test4
这里已经成功了apply到备库上去了。
实验2
PRIMARY> create table test.testobject as select * from dba_tables;
PRIMARY> commit
观察alert日志,没有归档的提示信息
redo日志没有满,所以没有切换
PRIMARY> insert into test.testobject select * from test.testobject;
多执行了几次,在alert日志,出现归档的信息。
用上面的方法查询,和主库一致。
STANDBY>select process,client_process,sequence#,status from v$managed_standby;
PROCESS CLIENT_P SEQUENCE# STATUS
--------- -------- ---------- ------------
ARCH ARCH 0 CONNECTED
ARCH ARCH 0 CONNECTED
ARCH ARCH 17 CLOSING
ARCH ARCH 0 CONNECTED
RFS N/A 0 IDLE
MRP0 N/A 18 WAIT_FOR_LOG
RFS LGWR 19 IDLE
RFS UNKNOWN 0 IDLE