DG之主库、备库切换(物理备库)

DG之主库、备库切换

一.开库与关库顺序


开库顺序


先启备库,再启主库(启动监听、打开告警日志)


关库顺序


先关主库,再关备库

二.主备库切换

1、操作过程一览

步骤1:启动备库、监听、告警;

步骤2:启动主库、监听、告警;

步骤3:主库(bj)查询信息

SQL>selectname,dbid,database_role,protection_mode from v$database;

步骤4:备库(sh)上做recover

SQL>recovermanaged standby database disconnect from session;

步骤5:备库上插入数据

SQL>insert into scott.emp1 select * from scott.emp;

报错

尽管备库处于open状态,但它是一个read-only状态。

步骤6:查看主库(bj)、备库(sh)日志是否一致

SQL>selectmax(sequence#) from v$archived_log where name is not null;

或SQL>selectmax(sequence#) from v$archived_log;

举例:

主库:

备库:

上图表明已经归档的最大序列号均为34,说明日志是同步的,能够进行主备库切换。

步骤7:主库(bj)下检查能否够切换

SQL>selectname,database_role,protection_mode,switchover_status from v$database;

switchover_status显示“TO STANDBY”表示同意做切换。

步骤8:备库(sh)下检查能否够切换

SQL>selectname,database_role,protection_mode,switchover_status from v$database;

说明:备库是不同意主动去切成主库的,NOT ALLOWED状态说明正常。

步骤9:检查主库(bj)上的会话

SQL>select username,sid from v$session where username is notnull;

查看是否仍实用户使用数据库,若仍有人使用,是不同意切换的,切换前要通知确保无用户使用。

步骤10:主库(bj)变为物理备库(sh)

若没有会话,将主库(bj)变为物理备库(sh)

SQL> ALTER DATABASECOMMIT TO SWITCHOVER TO PHYSICAL STANDBY;

若有会话的话,关闭会话,将主库(bj)变为物理备库(sh)

SQL>  alter database commit to switchover to physical standby withsession shutdown;

步骤11:关闭、重新启动之前的主库(bj)到mount状态

SQL> SHUTDOWN IMMEDIATE;

SQL> STARTUP MOUNT;

SQL> selectswitchover_status from v$database;

SWITCHOVER_STATUS

--------------------

TO PRIMARY

注:在这个时候,两个数据库都应该处于备库状态。

步骤12:查证备库的转换状态

SQL> SELECTSWITCHOVER_STATUS FROM V$DATABASE;

SWITCHOVER_STATUS

-----------------

TO_PRIMARY ——能够转换为主库,说明是备库状态

步骤13:将目标物理备库(sh)转换为主库

SQL> ALTER DATABASECOMMIT TO SWITCHOVER TO PRIMARY(WITHSESSION SHUTDOWN);

步骤14:完毕备库(sh)到主库转换,物理备库启动到open

若物理备库(bj)在近期一次启动时不是处于仅仅读模式 opened in read-only mode,直接将数据库打开,然后下一步。

SQL> select status fromv$instance;

STATUS

------------

MOUNTED

SQL> ALTER DATABASE OPEN;

SQL> select switchover_statusfrom v$database;

SWITCHOVER_STATUS

--------------------

TO STANDBY

若物理备库(bj)在近期一次启动时是仅仅读模式,则先将数据库正常关闭再起库。

SQL> SHUTDOWN IMMEDIATE;

SQL> STARTUP;

步骤15:在新备库(bj)上又一次开启日志应用

SQL> ALTER DATABASERECOVER MANAGED STANDBY DATABASE DISCONNECT FROM SESSION;

步骤16:在新的主库(sh)上切换日志,開始数据传输给备库

SQL> ALTER SYSTEM SWITCHLOGFILE;

SQL> /

SQL> select max(sequence#)from  v$archived_log;

MAX(SEQUENCE#)

--------------

56

SQL> col name for a50;

SQL> select  NAME ,SEQUENCE#  from v$archived_log; 查看归档日志

步骤17:在备库(bj)上查看归档,两值相等说明备库能收到日志

SQL> select max(sequence#)from  v$archived_log;

MAX(SEQUENCE#)

--------------

56

SQL> col name for a50;

SQL> select  NAME ,SEQUENCE#  from v$archived_log;  查看归档日志

2、总结主备库切换重点



主库


备库


查询是否能切换(应该显示同意)


备库查询是否能切换(应该显示不同意)


切换为物理备库


切换到mount状态


查看备库转换状态


转换为主库


切换到mount状态


启动到open


启动到open状态


开启日志应用


切换日志


查看归档序列号


查看归档序列号


查询状态:备库


查询状态:主库

***********************************************声明************************************************

原创作品,出自 “深蓝的blog” 博客,欢迎转载,转载时请务必注明出处(http://blog.csdn.net/huangyanlong)。

表述有错误之处,请您留言,不胜感激。

提醒:点击文件夹,更有助于您的查看。

*****************************************************************************************************

时间: 2025-01-22 02:46:01

DG之主库、备库切换(物理备库)的相关文章

大城小胖这几年积累的动画库、手势库、物理引擎库

过去几年陆陆续续的也在github上放了很多开源的项目. 但是由于自己也懒得推广 懒得维护  懒得写文档 和 demo, 所以大多数无人问津. 不过 最近打算好好折腾折腾他们. 希望能有点起色. 折腾的目的不是为了什么直接的利益. 只是希望如果有一天我死了 能给这个世界留下些什么 ( 我和你们一样, 也被这句话恶心到了... ) ================================ 以下项目除了最后一个, 其他的全是 js/HTML5 的. 刚体物理引擎 (功能不强大, 但是够我用了

Oracle 11g Data Guard 之物理备库角色转换

一.物理备库的Switchover操作 本节主要内容是物理备库的switchover操作,该操作起始于主库,结束于目标备库. 1.确认主库可以切换为standby角色 SQL> SELECT SWITCHOVER_STATUS FROM V$DATABASE; 如果结果显示TO STANDBY或者SESSIONS ACTIVE,则表明主库可以切换为standby角色,否则,切换操作将不可行,因为redo传输不是配置错误就是不能正常进行. 2.主库启动switchover 执行如下SQL语句将主库

oracle dg库switchover主备切换

switchover 切换:主库与备库数据同步正常情况下的切换,主要用于 主备维护.切换演练等: failover 切换:主库与备库在数据未同步情况下的强制切换,主要用 于主库宕机.故障情况下切换: 一.switchover 切换 主库与备库数据同步,且正常运行,将主库与备库的角色互换: 切换前,务必检查当前主库与备库的归档是否是同步的,确认同步后再执行切换 switchover 切换 主库操作 第1步.主库停止监听 lsnrctl stop (理论上是不需要停止主库监听的,但是实际上如果切换时

Oracle 11g Data Guard 物理备库快速配置指南(上)

缘起 最近做了10g和11g的物理备库配置实验,发现 Data Guard 其实很容易,但是缺少好文档.我是参考官方文档做的实验,觉得它写的不是很清楚的. Google 出来两个pdf文档,读了觉得比官方文档强很多.翻译下,也许会对某些朋友有用.翻译的同时我也好更熟悉下这两个文档.好久没翻译过英文了,可以顺便练练手. 原文档下载地址(墙外): Configure Dataguard 11gR2 Physical Standby Part 1 Configure Dataguard 11gR2 P

oracle11g dataguard物理备库搭建

Dataguard 环境: 操作系统:Redhat6.4 Primary数据库: IP 地址:192.168.1.122 数据库SID:ora11g DB_UNIQUE_NAME:ora11g_primary Standby数据库: IP 地址:192.168.1.123 数据库SID:ora11g DB_UNIQUE_NAME:ora11g_standby (注:oracle数据库版本是11.2.0.1.0) 1.Primary端的配置 (1).检查数据库是否支持 Data Guard(企业版

Oracle 11g Dataguard 暂停物理备库的日志传输

Oracle 11g Dataguard 暂停物理备库的日志传输分类: Oracle2017-07-18 10:03:17这两天生产端的日志产生过多导致灾备端的归档日志目录满的现象,在清除灾备端的日志后发现log_archive_dest_2处于error状态,需要将其enable.在实际生产系统中,通常有这样的场景,例如在系统维护日,对主库进行大量的业务更新,会有大量的DML操作:为了避免主库中的业务更新对备库造成影响,可以暂停主库对备库的日志传输,这样的话,如果主库的更新出现问题,备库还保留

Dataguard主、备库切换方法总结

Dataguard主.备库切换方法总结 2019-04-11 分类:Oracle 阅读(754) 评论(0) 文章目录[隐藏] 一.主备切换: 一.主备切换: 1.将主库切换成物理standby: alter database commit to switchover to physical standby with session shutdown; startup mount; 2.备库执行切换成primary,完成后数据库是mount,需要open: recover managed sta

搭建物理备库

Primary db configure:1. 开启主库强制日志 查询当前是否强制日志: SQL> select force_logging from v$database;  FOR --- NO  开启强制日志 SQL> alter database force logging;  Database altered.  查询 SQL> select force_logging from v$database;  FOR --- YES2. 开启归档模式 SQL> alter s

linux下oracle11G DG搭建(三):围绕备库搭建操作

环境 名称 主库 备库 主机名 bjsrv shsrv 软件版本 RedHat Enterprise5.5.Oracle 11g 11.2.0.1 RedHat Enterprise5.5.Oracle 11g 11.2.0.1 三.围绕备库操作: 1.备库-修改初始化参数文件 $cd$ORACLE_HOME/dbs $df -h $vi initshdb.ora 修改简要说明: *.audit_file_dest='/u01/app/oracle/admin/sh/adump' //审计文件存