0

朋友们!我们在服务器上的 Data Guard 配置中有很多主数据库及其物理备用数据库。单个服务器上的每个主数据库和单个服务器上的每个物理备用数据库。在 EM12c 中,我们为备份主数据库配置了调度程序作业。不幸的是,当服务器真的很忙时,代理会暂停备份执行,我们没有按照计划进行备份。

因此,我们从 EM12c 禁用了我们的备份作业,并希望使用过程在物理备用上执行备份DBMS_SCHEDULER.CREATE_JOB

由于物理备用是只读数据库和主数据库的每个块副本,我必须在主数据库上创建计划作业并将其应用于备用数据库。

所以,问题是:这可能吗?如果,是的 - 如何在脚本中实现这一点?

像这样的东西:

check database_role 
if role='PHYSICAL STANDBY' 
then execute backup script 
else nothing to do..

如果不可能,哪种解决方案最适合解决此任务?有没有办法解决这个问题而无需在每台服务器上使用单个脚本创建 cron 任务?是否可以使用恢复目录数据库中的一个全局脚本?

Kris 说,我无法从物理备用数据库运行计划作业。因此,我将使用 crontab 安排我的 linux 脚本。我的linux脚本是:

#! /usr/bin/bash

LOG_PATH=/home/oracle/scripts/logs; export LOG_PATH
TASK_NAME=backup_database_inc0; export TASK_NAME
CUR_DATE=`date +%Y.%m.%d-%H:%M`; export CUR_DATE
LOGFILE=$LOG_PATH/$TASK_NAME.$CUR_DATE.log; export LOGFILE

    rman target / catalog rmancat/<pswd>@rmancat script 'backup_database' log $LOGFILE

    if [ $? -eq 0 ]
    then
      mail -s "$ORACLE_UNQNAME Backup Status: SUCCESS" dba@server.mail< $LOGFILE
      exit 0
    else
      mail -s "$ORACLE_UNQNAME Backup Status: FAILED" dba@server.mail< $LOGFILE
      exit 1

我不想在每个主机上创建 linux 文件来从我的恢复目录中调用备份全局脚本。是否可以在所有主机上配置集中备份执行计划?我可以将 ssh 从一台主机配置到所有数据库主机并执行我的 linux 脚本进行备份吗?

提前感谢您的回答。

4

1 回答 1

0

我强烈建议使用 Enterprise Manager 来运行备份作业。EM 与 rman 目录和每个实例很好地集成,因此您可以只设置 rman 执行全局脚本命令。其他一切都由 EM 完成。

我将作业安排为仅通过 EM 作业调度程序在备用服务器上运行,而无需在切换期间进行任何更改。

我只需要级联工作。所以我有一步检查目标是否处于待机状态,如果该步骤成功,那么我正在运行备份。如果不是,则下一步不会运行。

这样,监控也与全局数据库监控相结合。您不必在操作系统级别的 shell 脚本中设置错误捕获。

于 2017-03-17T10:48:21.567 回答