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 切换完成;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。