朋友们!我们在服务器上的 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 脚本进行备份吗?
提前感谢您的回答。