physical standby是怎么转换snapshot standby database
这篇文章将为大家详细讲解有关physical standby是怎么转换snapshot standby database,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
physical standby---------->snapshot standby database
1 | 如果apply service 是活动的,那么停止redo apply |
2 | 确保数据库是mount 状态 |
3 | 确保fast recovery area已经配置,但不需要启动flashback database功能 |
4 | ALTER DATABASE CONVERT TO SNAPSHOT STANDBY; |
过程如何
1.验证fast recovery area是否配置
SYS@dogg> show parameter DB_RECOVERY_FILE_DEST
NAME TYPE VALUE
------------------------------------ ----------- ------------------------------
db_recovery_file_dest tring /u01/app/oracle/fast_recovery_area
db_recovery_file_dest_size big integer 10G
-----db_recovery_file_dest_size 如果太小通过下面语句调整
alter system set db_recovery_file_dest_size=10g scope=both;
2.查看redo 是否redo apply
SYS@dogg> select process,status from v$managed_standby;
---如果引用,那么取消
SYS@dogg> alter database recover managed standby database cancel;
3.关闭数据库,启动到mount
SYS@dogg> shutdown immediate
SYS@dogg> startup mount;
4.执行切换
SYS@dogg> alter database convert to snapshot standby;
5.打开数据库,并查看模式
SYS@dogg> alter database open;
SYS@dogg> select open_mode from v$database;
OPEN_MODE
--------------------
READ WRITE
---可以看到备库是读写模式
6.到主库查看最后一个归档
SYS@ogg> select max(sequence#) from v$archived_log;
MAX(SEQUENCE#)
--------------
101
7.到备库查看收到的最后一个归档
SYS@ogg> select max(sequence#) from v$archived_log;
MAX(SEQUENCE#)
--------------
101
8.备库查询最后一个应用的归档
SYS@dogg> SELECT THREAD#, MAX(SEQUENCE#) AS "LAST_APPLIED_LOG" FROM V$LOG_HISTORY GROUP BY THREAD#;
THREAD# LAST_APPLIED_LOG
---------- ----------------
1 97
------这里验证了 snapshot standby database只接受 不应用
关于physical standby是怎么转换snapshot standby database就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。