oracle dg库switchover主备切换
admin
2023-04-30 21:04:18
0

switchover 

切换:主库与备库数据同步正常情况下的切换,主要用于

主备维护、切换演练等;

 

failover 

切换:主库与备库在数据未同步情况下的强制切换,主要用

于主库宕机、故障情况下切换;

 

 

一、switchover 切换 

主库与备库数据同步,且正常运行,将主库与备库的角色互换;

切换前,务必检查当前主库与备库的归档是否是同步的,确认同步后再执行切换

 

switchover 切换 主库操作

 

第1步、主库停止监听  

lsnrctl stop

(理论上是不需要停止主库监听的,但是实际上如果切换时数据库繁忙,还有大量会话连接操作数据库,在执行切换操作的时候需要等待oracle执行session shutdown,有时会很慢,这里建议直接停止监听,停止后,还可以通过查 ps -ef | grep "LOCAL=NO",查看进行, LOCAL=NO是客户端连接进程,并kill -9 杀掉这些没有释放的连接,再执行下面的切换)

 ps -ef | grep "LOCAL=NO" | grep -v grep | awk '{print $2}' | xargs kill -9 

 

第2步、主库执行切换 

主库状态角色确认 

select switchover_status from v$database;

 

查询结果分两种情况: 

第一种情况 

SQL> select switchover_status from v$database; 

 

SWITCHOVER_STATUS 

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

SESSIONS ACTIVE

如果查询结果是SESSIONS ACTIVE:执行下面的: 

SQL>alter database commit to switchover to physical standby w

ith session shutdown;

 

第二种情况

SQL> select switchover_status from v$database; 

 

SWITCHOVER_STATUS 

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

TO STANDBY 

如果查询结果是:TO STANDBY 执行下面的: 

SQL>alter database commit to switchover to physical standby;

 

 

第3步、关闭主库 

SQL>shutdown immediate 

ORA-01507: database not mounted 

ORACLE instance shut down. 

 

第4步、主库启动到mount状态 

SQL>startup mount

 

ORACLE instance started. 

Total System Global Area 9646899200 bytes 

Fixed Size 2087000 bytes 

Variable Size 822085544 bytes 

Database Buffers 8808038400 bytes 

Redo Buffers 14688256 bytes

Database mounted. 

 

第5步、主库确定切换后的状态 

SQL>select open_mode,database_role,switchover_status from v$database; 

 

OPEN_MODE DATABASE_ROLE SWITCHOVER_STATUS 

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

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

MOUNTED PHYSICAL STANDBY SESSIONS ACTIVE  

数据库角色变成了PHYSICAL STANDBY(物理备库),完成了主库的角色转换;

 

第6步、主库启动监听 

lsnrctl start

 

 

switchover 切换备库操作

 

备库执行切换为主库模式

 

第1步、备库状态角色确认 

SQL>select switchover_status from v$database;

  

第一种情况 

SQL> select switchover_status from v$database; 

SWITCHOVER_STATUS 

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

TO PRIMARY 

如果状态为TO PRIMARY 则执行下面的语句: 

SQL>alter database commit to switchover to primary;

 

第二种情况 

SQL> select switchover_status from v$database; 

SWITCHOVER_STATUS 

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

SESSIONS ACTIVE 

如果状态是SESSIONS ACTIVE 则执行下面的语句: 

alter database commit to switchover to primary with session shutdown; 

 

第2步、备库打开

 alter database open; 

 

第3步、备库状态角色确认 

SQL>select open_mode,database_role,switchover_status from v$database;

 

OPEN_MODE DATABASE_ROLE SWITCHOVER_STATUS 

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

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

READ WRITE PRIMARY

 SESSIONS ACTIVE 

 

 

第4步、原主库启动同步

 在原主库上执行: 

SQL>ALTER DATABASE OPEN;

SQL>ALTER DATABASE RECOVER MANAGED STANDBY DATABASE USING CURRENT LOGFILE DISCONNECT FROM SESSION;

 

switchover 切换完成;


相关内容

热门资讯

奥特曼出庭:马斯克不仅想掌控O... 澎湃新闻记者 吴遇利硅谷顶尖科技巨头间的法律博弈进入了关键质证阶段。据外媒报道,当地时间5月12日,...
沙特、阿联酋被曝曾秘密空袭伊朗... 澎湃新闻记者 朱郑勇 实习生 诸丽雯据新华社此前报道,1月28日,沙特王储本·萨勒曼曾表示不允许任何...
男生偷拍女生被连夜开除,学历再... 据央视新闻报道,记者从南京审计大学获悉,经查,该校学生顾某某在校内偷拍他人隐私情况属实,且情节严重。...
“台独”顽固分子刘世芳外甥被台... 5月13日,国务院台办举行例行新闻发布会。有记者问:对于“台独”顽固分子刘世芳外甥颜文群被所在台企解...
1至4月全国铁路完成固定资产投... 【大河财立方消息】 5月13日,国铁集团发布的数据显示,今年1至4月,铁路建设优质高效推进,全国铁路...
了不起的河洛文化丨巩义的盛唐物... 巩义出土的唐三彩。 河南省文物考古研究院供图近日,郑州市文物考古研究院考古博物馆二楼报告厅举办了一场...
方太油烟机自动排烟故障 方太油烟机是一款高品质的厨房电器,它能够有效地吸收和排除厨房产生的油烟,保持室内空气的清新。然而,在...
方太油烟机的油烟怎么处理 方太油烟机是一种能够清除厨房油烟的设备,可以有效的净化厨房空气,减少油烟对人体的危害。但是,油烟机使...
方太油烟机尺寸为什么有大有小 在挑选抽油烟机时,抽油烟机的尺寸是重点考虑问题。如果购买到的抽油烟机尺寸过大,必然会占用太多空间,甚...
邻妹妹帮办|冷冻玉米长黑斑仍在... “玉米霉变非常明显,超市还在售卖!”近日,信阳市浉河区湖东街道辖区居民李女士向大河报·邻妹妹反映,其...