首页  ·  知识 ·  数据库
CRONTAB调用备份脚本时注意事项
网友    Oracle  编辑:dezai   图片来源:网络
CRONTAB调用备份脚本时要注意环境变量的设置是本文我们主要要介绍的内容,我们知道,EXP备份是DBA常规操作之一,尤其是10g以前的版本没有EXPDP,所有的逻辑备份都是通过EXP来实现.而将EXP写成SHELL
CRONTAB调用备份脚本时要注意环境变量的设置是本文我们主要要介绍的内容,我们知道,EXP备份是DBA常规操作之一,尤其是10g以前的版本没有EXPDP,所有的逻辑备份都是通过EXP来实现.而将EXP写成SHELL脚本,使之可以调用也并没有什么特别之处.不过如果并非oracle用户执行,而是需要CRONTAB自动允许,那么备份的脚本就有一些要求了.

  客户环境使用RMAN CATALOG方式备份,而RMAN的CATALOG数据库采用EXP进行逻辑备份.部署了一个每天7点运行的CRONTAB,调用执行EXP的SHELL.巡检时发现这个脚本从未真正运行过.

  /app/oracle10g> crontab -l

  0 7 * * * /app/oracle10g/rman_catalog_dmp/exp_by_date.sh

  /app/oracle10g/rman_catalog_dmp> more exp_by_date.sh

  export ORACLE_SID=RMANDB export ORACLE_BASE=/app/oracle10g

  export ORACLE_HOME=$ORACLE_BASE/product/10.2.0

  export NLS_LANG=American_America.ZHS16CGB231280

  exp parfile=exp.par file=./rman_catalog.dmp log=./rman_catalog.log

  由于是CRONTAB进行调用,因此不会使用oracle用户的环境变量,这就需要在shell脚本中添加必要的环境变量的设置,这才能是的EXP命令可以正确的运行.脚本中虽然已经设置了一些环境变量,但是还是不够的.

  对于CRONTAB运行SHELL时出现的错误,可以通过用户的mail来获取错误信息:

  /app/oracle10g/rman_catalog_dmp> mail

  From root@acap3 Thu Aug 18 07:00:01 EAT 2011

  Received: (from root@localhost)

  by acap3 (8.9.3 (PHNE_35950)/8.9.3) id HAA27754

  for oracle; Thu, 18 Aug 2011 07:00:01 +0800 (EAT)

  Date: Thu, 18 Aug 2011 07:00:01 +0800 (EAT)

  From: root@acap3

  Message-Id: <201108172300.HAA27754@acap3> Subject: cron

  /app/oracle10g/rman_catalog_dmp/exp_by_date.sh[5]: exp: not found.

  *************************************************

  Cron: The previous message is the standard output

  and standard error of one of your crontab commands:

  /app/oracle10g/rman_catalog_dmp/exp_by_date.sh

  显然导致错误的原因是执行EXP命令时,在默认目录下没有找到EXP可执行命令,显然脚本中漏设了PATH环境变量.

  增加PATH=$ORACLE_HOME/bin环境变量后,再次测试发现,参数文件找不到,仿照导出文件和日志文件的方式,将参数文件设置为./exp.par,问题依旧.看来在CRONTAB中调用SHELL,应该设置绝对路径,而不能设置相对路径.

  最终脚本修改为:

  /app/oracle10g/rman_catalog_dmp> more /app/oracle10g/rman_catalog_dmp/exp_by_date.sh

  export ORACLE_SID=RMANDB

  export ORACLE_BASE=/app/oracle10g

  export ORACLE_HOME=$ORACLE_BASE/product/10.2.0

  export NLS_LANG=American_America.ZHS16CGB231280

  export PATH=$ORACLE_HOME/bin:$PATH

  DATE=`date +"%Y%m%d"`

  exp parfile=/app/oracle10g/rman_catalog_dmp/exp.par file=/app/oracle10g/rman_catalog_dmp/rman_catalog_$DATE.dmp log=/app/oracle10g/rman_cat

  alog_dmp/rman_catalog_$DATE.log you have mail in /var/mail/oracle

  利用CRONTAB来实现SHELL的自动调用,需要注意两个问题,第一是否在SHELL中设置了必要的环境变量;第二尽量所有的文件都采用完全路径方式,避免使用相对路径.

  关于CRONTAB调用备份脚本时要注意环境变量的设置的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!

  考试大温馨提示:本内容来源于网络,仅代表作者个人观点,与本站立场无关,仅供您学习交流使用。其中可能有部分文章经过多次转载而造成文章内容缺失、错误或文章作者不详等问题,请您谅解。如有侵犯您的权利,请联系我们,本站会立即予以处理。

本文作者:网友 来源:网络
CIO之家 www.ciozj.com 微信公众号:imciow
   
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。
延伸阅读