为大家分享一个【Oracle ADG自动切换】的脚本,由云和恩墨工程师HongyeDBA编写,支持Switchover、Failover。

下载链接:https://www.modb.pro/download/5

DG环境需求

  • DG使用服务名必须静态注册
  • 切换机器必须安装oracle client
  • 切换机器配置tnsnames.ora(需要连接到主库和备库,Rac需要配置多个节点的Tns别名)
  • 程序不进行自动判断是否Failover操作
  • 如果需要mount磁盘组,必须配置log_file_name_convert

额外环境说明

Switchover

  • 主库使用SESSION SHUTDOWN进行切换
  • 备库正常激活

Failover

  • 如果主库存活

    主库会尝试使用flush redo to dg进行操作(仅支持11G)

  • 如果主库不存活,存在存储复制(仅支持ASM)

    存在存储复制把redo和控制文件复制到备端,请激活存储复制盘并设置正确的权限

    脚本会尝试使用此控制文件和redo进行起库,如果启动会尝试使用备库控制文件启动(在此失败请人工处理)

  • 如果主库不存活,不存在存储复制

    主动激活备库

参数说明

INFO: InitLogfile Logfile : /tmp/dgSwitch-travel.trc
=============================================================================
This script is used to Switch Oracle Database DataGuard.
=============================================================================
Usage :
perl dgSwitch.pl -P <SYS's Password> -p <TNS Alias> -s <TNS Alias>
-P : Specify the Password for SYS User, default:oracle
-p : Specify the Operation Node for Primary Site
: Rac Need All nodes [-p "orcl1 orcl2"]
-s : Specify the Operation Node for Standby Site
: Rac Need All nodes [-p "orcldg1 orcldg2"] -f : Use Failover Method to do Switchover
-m : Standby Database Machine Memory Size(Mb)
: if set program Auto Set Sga , if not set not modify Sga Parameter
-i : ignore database params check
-c : Only Check Something,same -S 0
-S : <step #> Run the step # at a timeOnly Run One Step
-r : <num-num> Run the steps one after the other as long as no errors
Demo :
Single:Single : dgSwitch.pl -p orcl -s orcldg
Rac:Single : dgSwitch.pl -p "orcl1 orcl2" -s orcldg
Single:Rac : dgSwitch.pl -p orcl -s "orcldg1 orcldg2"
Rac:Rac : dgSwitch.pl -p "orcl1 orcl2" -s "orcldg1 orcldg2"
Need :
: Will Query V$DATABSAE、DBA_HIST_TEMPFILE、DBA_TABLESPACES、DBA_TEMP_FILES
: static register listener ,port 1522
: please set db_create_file_dest
: please set db_recovery_file_dest,db_recovery_file_dest_size
=============================================================================
  • P sys用户密码,默认密码Oracle
  • p 主库的tns别名,Rac需要输入多个,自动取其中之一进行switch操作
  • s 备库的tns别名,Rac需要输入多个,自动取其中之一进行switch操作
  • f 明确指定进行failover操作
  • c 尽进行DG check检查
  • m 指定备机的主机内存,会执行设置SGA操作
  • i 忽略检查过程中判断参数问题
  • S 执行单独的一步(大写),如
    • -S 0 执行检查步骤
    • -S 1 主库进行切换操作
    • -S 2 备库进行切换操作
    • -S 3 新主库进行切换操作
    • -S 4 新住库解决临时表空间操作
    • -S 5 新主库解决服务名切换操作
    • -S 6 Redo处理操作
    • -S 7 新备库进行切换操作
    • -S 8 切换完成后检查
  • r 执行多个步骤,如
    • -r 0-8 全部执行,默认步骤
    • -r 0-6 DG切换,并只完成主库操作
    • -r 7-8 完成源主库操作

切换步骤

切换暂时分为8步,0-7如下

./dgSwitch.pl -p orcl -s orcldg -l
INFO: InitLogfile Logfile : /tmp/dgSwitch-travel.trc
The steps in order are...
Step 0 = CheckDbStatus
Step 1 = primaryOP
Step 2 = standbyOP
Step 3 = NewprimaryOP
Step 4 = resolveTmp
Step 5 = CheckService
Step 6 = CheckRedo
Step 7 = newstandbyOP
Step 8 = CheckDBAfter

程序切换流程图

failover

./dgSwitch.pl -p orcl -s orcldg -f

知道flashback,会在failover时打开flaskback

./dgSwitch.pl -p orcl -s orcldg -f --flashback


查看下载链接https://www.modb.pro/download/5

墨天轮,围绕数据人的学习成长提供一站式的全面服务,打造集新闻资讯、在线问答、活动直播、在线课程、文档阅览、资源下载、知识分享及在线运维为一体的统一平台,持续促进数据领域的知识传播和技术创新。

关注官方公众号: 墨天轮、 墨天轮平台、墨天轮成长营、数据库国产化 、数据库资讯

Oracle ADG 自动切换脚本分享的更多相关文章

  1. oracle expdp自动备份脚本

    windows: @echo off echo ================================================ echo Windows环境下Oracle数据库的自动 ...

  2. IP自动切换脚本

    @echo off & cls & color 47 & mode con cols=80 lines=25 & title [IP自动切换工具]clsecho. ec ...

  3. oracle数据库自动备份脚本

    ::通过exp命令导出远程机器(192.168.2.1)上指定服务(orcl)指定用户(pmis)及密码(pmis)的数据 ::运行该脚本的机器必须安装oracle @echo off @echo [ ...

  4. mysql+keepalived主从切换脚本 转

    Keepalived MySQL故障自动切换脚本   MySQL架构为master-slave(主从),master故障自动切换到slave上.当然也可以设置为双master,但这里有个弊端:就是当主 ...

  5. Windows下Oracle数据库自动备份批处理脚本

    expdb命令版本 @echo off REM ########################################################### REM # Windows Se ...

  6. SQL Server定时自动抓取耗时SQL并归档数据发邮件脚本分享

    SQL Server定时自动抓取耗时SQL并归档数据发邮件脚本分享 第一步建库和建表 USE [master] GO CREATE DATABASE [MonitorElapsedHighSQL] G ...

  7. Windows环境下Oracle数据库的自动备份脚本

    批处理文件(.bat) @echo off echo ================================================ echo  Windows环境下Oracle数据 ...

  8. Oracle自动备份脚本(网上找到的资料)

    废话不多说了,直接给大家贴代码了,具体代码如下所示: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 ...

  9. Linux oracle数据库自动备份自动压缩脚本代码

    Linux oracle数据库备份完成后可以自动压缩脚本代码. 复制代码代码如下: #!/bin/bash #backup.sh #edit: www.jbxue.com ##系统名称 sysname ...

  10. SQL Server定时自动抓取耗时SQL并归档数据脚本分享

    原文:SQL Server定时自动抓取耗时SQL并归档数据脚本分享 SQL Server定时自动抓取耗时SQL并归档数据脚本分享 第一步建库 USE [master] GO CREATE DATABA ...

随机推荐

  1. HTML+JavaScript+CSS做一个界面

    下面是一个web界面主要是前端没有后端功能:关于JavaScript几种比较常见的样式   Javaweb(1),html <!DOCTYPE html> <html lang=&q ...

  2. Python和RPA网页自动化-让非标准下拉框选择指定文本的方法

    以下方"节点审批"下拉框为例 该下拉框没有<select>标签,而是<div><ul><li>标签.分别使用Python和RPA网页 ...

  3. Jmeter函数助手37-setProperty

    setProperty函数用于修改jmeter属性值. 属性名称:填入需要修改的属性名 Value of property:填入需要修改的属性值 Return Original Value of pr ...

  4. 对比python学julia(第三章:游戏编程)--(第一节)初识游戏库(3)

    1.1.    键盘和鼠标控制 在游戏应用程序中,通常使用键盘和鼠标作为游戏的操作设备.游戏的窗口都能接收来自键盘和鼠标设备的输人.当用户在键盘上按下按建或释放按键时,会产生相应的键盘事件:当用户移动 ...

  5. 【MacOS】VMware安装10.15-Catalina版本

    参考自: https://www.bilibili.com/video/BV1sf4y1D77A?p=4 资源地址: https://pan.baidu.com/s/1U6WOorb_TuORQ9ab ...

  6. 【Lodop】01 Lodop手册阅读上手

    官方网站: http://www.c-lodop.com/index.html 版本:6.2.2.6 一.概述 Lodop是一款用于WEB打印开发的专业WEB打印控件 控件发布包有3个系统文件组成,主 ...

  7. 分享某Python下的mpi教程 —— A Python Introduction to Parallel Programming with MPI 1.0.2 documentation ( 续 #2 )

    接前文: 分享某Python下的mpi教程 -- A Python Introduction to Parallel Programming with MPI 1.0.2 documentation ...

  8. fastDFS安装时,./make.sh编译时出错找不到./make.sh: line 99: perl: command not found

    1.背景 报错如下: 2.解决方案 执行命令: yum -y install zlib zlib-devel pcre pcre-devel gcc gcc-c++ openssl openssl-d ...

  9. redis集群之哨兵模式

    redis集群之哨兵模式 1.集群部署 安装配置可参考一下地址: https://www.cnblogs.com/zhoujinyi/p/5569462.html 2.与springboot集成 这里 ...

  10. Unity FpsSample Demo研究

    1.前言 Unity FpsSample Demo大约是2018发布,用于官方演示MLAPI(NetCode前身)+DOTS的一个FPS多人对战Demo. Demo下载地址(需要安装Git LFS) ...