dataguard switchover的自动化脚本实现 (r5笔记第48天)
时间:2022-05-04
本文章向大家介绍dataguard switchover的自动化脚本实现 (r5笔记第48天),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
data guard的主要功能就是作为备库来同步主库的数据变化,一般使用中物理standby使用的比较多。data guard显示威力的一个场景就是swithover了,即主备切换。这种切换方式执行时间很短,能够在一些灾难场景中极大的提高系统的可用性和稳定性。 自己在本地的环境中搭建了一套data guard的环境,开始比较生疏,切换中碰到了不少的问题,最后搭建完成,把切换中的一些细节信息都总结起来,整理成了一个初步的脚本。能够很方便的实现swithover 这个脚本适用于物理standby,在本地环境中反复测试,切换了十多次,还算是比较稳定的。 在脚本中也对需要切换的实例进行了基本的校验,保证不会出现低级错误。比如主库切为主库,备库切为备库等等。 当然对于一些更加细节的信息没有做过滤,比如对于归档gap的判定等。
PRI_DB=`sqlplus -s sys/oracle@$1 as sysdba <<EOF
set feedback off
set pages 0
select database_role from v\$database;
EOF`
echo $PRI_DB
if [[ $PRI_DB = 'PHYSICAL STANDBY' ]]
then echo 'PRIMARY DB INSTANCE IS NOT '$1 ',PLEASE CHECK AGAIN'
exit
fi
PRI_DB=$1
#echo $PRI_DB
STD_DB=`sqlplus -s sys/oracle@$2 as sysdba <<EOF
set feedback off
set pages 0
select database_role from v\$database;
EOF`
if [[ $STD_DB = 'PRIMARY' ]]
then echo 'STANDBY DB INSTANCE IS NOT '$2 ',PLEASE CHECK AGAIN'
exit
fi
STD_DB=$2
#export ORACLE_SID=$STD_DB
sqlplus -s sys/oracle@$PRI_DB as sysdba <<EOF
break on db_name
set pages 50
set linesize 100
prompt
prompt Primary Instance
prompt ~~~~~~~~~~~~~~~~
select d.dbid dbid
, d.name db_name
, i.instance_number inst_num
, i.instance_name inst_name
, d.database_role
from v$database d,
v$instance i;
EOF
#export ORACLE_SID=$STD_DB
sqlplus -s sys/oracle@$STD_DB as sysdba <<EOF
break on db_name
set pages 50
set linesize 100
prompt
prompt Standby Instance
prompt ~~~~~~~~~~~~~~~~
select d.dbid dbid
, d.name db_name
, i.instance_number inst_num
, i.instance_name inst_name
, d.database_role
from v$database d,
v$instance i;
EOF
sqlplus sys/oracle@$STD_DB as sysdba <<EOF
prompt recover managed standby database cancel;
recover managed standby database cancel;
EOF
#export ORACLE_SID=$PRI_DB
sqlplus sys/oracle@$PRI_DB as sysdba <<EOF
prompt Alter database commit to switchover to physical standby with session shutdown;
Alter database commit to switchover to physical standby with session shutdown;
EOF
sqlplus sys/oracle@$PRI_DB as sysdba <<EOF
prompt shutdown immediate;
shutdown immediate;
EOF
sqlplus sys/oracle@$PRI_DB as sysdba <<EOF
prompt startup mount
startup mount
prompt recover managed standby database disconnect from session;
recover managed standby database disconnect from session;
EOF
#export ORACLE_SID=$STD_DB
sqlplus sys/oracle@$STD_DB as sysdba <<EOF
Select name,switchover_status from v$database;
prompt alter database recover managed standby database finish force;
alter database recover managed standby database finish force;
select name,switchover_status from v$database;
prompt alter database commit to switchover to primary;
alter database commit to switchover to primary;
select name,database_role from v$database;
select instance_name,status from v$instance;
prompt alter database open;
alter database open;
EOF
切换的日志如下,限于篇幅,适当做了整理。
Primary Instance
~~~~~~~~~~~~~~~~
DBID DB_NAME INST_NUM INST_NAME DATABASE_ROLE
---------- --------- ---------- ---------------- ----------------
1028247664 TEST11G 1 TEST11G PRIMARY
Standby Instance
~~~~~~~~~~~~~~~~
DBID DB_NAME INST_NUM INST_NAME DATABASE_ROLE
---------- --------- ---------- ---------------- ----------------
1028247664 TEST11G 1 DG11G PHYSICAL STANDBY
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
idle> recover managed standby database cancel
idle> Media recovery complete.
idle>
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
sys@TEST11G> Alter database commit to switchover to physical standby with session shutdown
sys@TEST11G>
Database altered.
sys@TEST11G>
idle> shutdown immediate
idle> ORA-01507: database not mounted
ORACLE instance shut down.
Connected to an idle instance.
idle> startup mount
idle> ORACLE instance started.
Total System Global Area 435224576 bytes
Fixed Size 1337044 bytes
Variable Size 272632108 bytes
Database Buffers 155189248 bytes
Redo Buffers 6066176 bytes
Database mounted.
idle> recover managed standby database disconnect from session
idle> Media recovery complete.
NAME SWITCHOVER_STATUS
--------- --------------------
TEST11G SWITCHOVER LATENT
idle> alter database recover managed standby database finish force
idle>
Database altered.
NAME SWITCHOVER_STATUS
--------- --------------------
TEST11G TO PRIMARY
idle> alter database commit to switchover to primary
idle>
Database altered.
NAME DATABASE_ROLE
--------- ----------------
TEST11G PRIMARY
idle>
INSTANCE_NAME STATUS
---------------- ------------
DG11G MOUNTED
idle> alter database open
idle>
Database altered.
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 网页轮播图案例
- Angular单元测试ComponentFixture的实例化过程明细
- 如何在Chrome调试器里检查嵌套Observable对象
- Angular 指令ngTemplateOutlet的运行原理单步调试
- 跳出源码地狱,Spring巧用三级缓存解决循环依赖-原理篇
- Angular NgTemplateOutlet的一个例子
- 手把手教你自制基于TencentOS Tiny的智能甲醛监测仪
- ASP.NET Core 使用 AutoFac 注入 DbContext
- Python爬虫练习:爬取800多所大学学校排名、星级等
- Python爬取股票信息,并实现可视化数据
- Python爬虫练习:爬取素材网站数据
- 25行代码带你爬取4399小游戏数据,看下童年的游戏是否还在
- 十一假期快到了,不知道该去哪玩?爬取旅游攻略
- 干掉Navicat:正版 MySQL 官方客户端真香!
- WordPress评论插件wpDiscuz任意文件上传复现