从这期开始讲Oracle Data Guard方面的内容
Data Guard作为Oracle提供的一个高可用及灾备解决方案,理解并可以实施它对于DBA来说是非常重要套的技能
前面我们已经介绍了如何假设物理备库,今天介绍日常如何运维和如何开启ADG
1. Data Guard状态查看
select dest_name,
status,
target,
ARCHIVER,
destination,
log_sequence,
valid_type,
valid_rolefrom V$ARCHIVE_DEST;
这个视图可以看到归档日志的一些配置信息
select dest_name,
type,
database_mode,
recovery_mode,
protection_mode,
destination,
SRL,
GAP_STATUS
from V$ARCHIVE_DEST_STATUS;
这个视图的信息比上个更加的具体,包括保护模式,应用模式等
select * from V$ARCHIVE_GAP;
select name,log_mode,open_mode,protection_mode
from V$DATABASE;
select*from V$DATAGUARD_STATS;
select * from V$LOG;
select * from V$LOGFILE;
select* from V$STANDBY_LOG;
这里UNASSIGNED是由于负载较轻导致
相关的视图简单介绍到这,具体请参见官方文档
https://docs.oracle.com/cd/E11882_01/server.112/e41134/views.htm#SBYDB01300
请确保备库处于同步状态
alter database set standby database to maximize availability;
alter database set standby database to maximize protection;
alter database set standby database to maximize availability;
alter database set standby database to maximize performance;
注意:不可直接从performance切换到 protection
SQL>alter database recover managed standby database cancel;
SQL>startup nomount;
SQL>alter database mount standby database;
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;
SQL>alter database recover managed standby database disconnect from session;
3.2.2.1 延迟4小时同步
SQL>alter database recover managed standby database delay 240 disconnect from session;
3.2.2.2 取消延迟
SQL> ALTER DATABASE RECOVER MANAGED STANDBY DATABASE NODELAY;
有时备库的归档文件不是主库传输的而是手动拷贝过来的,需要注册才能够应用
SQL> ALTER DATABASE REGISTER LOGFILE '/oracle/NP1/oraarch/NP1arch/1_224744_671386971.dbf';
Oracle 11g提供了ADG功能
让我们在物理备库处于Open read only状态时可以继续应用日志
如果处于同步状态需要先关闭
SQL> alter database recover managed standby database cancel;
SQL> alter database open read only;
SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT;
这时ADG已经开启,可以保证数据一致的情况下提供只读功能
查询V$ARCHIVE_DEST视图看是否有错误,并查看alert日志
一般有如下情形
备库的控制文件不能是如下形式
好了,到这里我们讲了DG日常的一些运维操作,下一节讲如何进行switchover