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

php中文网
发布: 2016-06-07 15:58:22
原创
2294人浏览过

DG之主库、备库切换 一.开库与关库顺序 开库顺序 先启备库,再启主库(启动监听、打开告警日志) 关库顺序 先关主库,再关备库 二.主备库切换 1、操作过程一览 步骤1:启动备库、监听、告警; 步骤2:启动主库、监听、告警; 步骤3:主库(bj)查询信息 SQ

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

DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

DeepSeek 10435
查看详情 DeepSeek

若物理备库(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)。

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

提醒:点击目录,更有助于您的查看。

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

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号