CRONTAB调用备份脚本时要注意环境变量的设置详解

数据库 Oracle
本文我们主要介绍了CRONTAB调用备份脚本时要注意环境变量的设置过程,希望能够对您有所帮助。

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

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

 

  1. /app/oracle10g> crontab -l  
  2. 0 7 * * * /app/oracle10g/rman_catalog_dmp/exp_by_date.sh  
  3. /app/oracle10g/rman_catalog_dmp> more exp_by_date.sh   
  4. export ORACLE_SID=RMANDB 
  5. export ORACLE_BASE=/app/oracle10g  
  6. export ORACLE_HOME=$ORACLE_BASE/product/10.2.0  
  7. export NLS_LANG=American_America.ZHS16CGB231280  
  8. exp parfile=exp.par file=./rman_catalog.dmp log=./rman_catalog.log 

 

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

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

 

  1. /app/oracle10g/rman_catalog_dmp> mail  
  2. From root@acap3 Thu Aug 18 07:00:01 EAT 2011  
  3. Received: (from root@localhost)  
  4. by acap3 (8.9.3 (PHNE_35950)/8.9.3) id HAA27754  
  5. for oracle; Thu, 18 Aug 2011 07:00:01 +0800 (EAT)  
  6. Date: Thu, 18 Aug 2011 07:00:01 +0800 (EAT)  
  7. From: root@acap3  
  8. Message-Id: <201108172300.HAA27754@acap3> 
  9. Subject: cron  
  10. /app/oracle10g/rman_catalog_dmp/exp_by_date.sh[5]: exp: not found.  
  11. *************************************************  
  12. Cron: The previous message is the standard output  
  13. and standard error of one of your crontab commands:  
  14.  
  15. /app/oracle10g/rman_catalog_dmp/exp_by_date.sh 

 

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

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

最终脚本修改为:

 

  1. /app/oracle10g/rman_catalog_dmp> more /app/oracle10g/rman_catalog_dmp/exp_by_date.sh  
  2. export ORACLE_SID=RMANDB 
  3. export ORACLE_BASE=/app/oracle10g  
  4. export ORACLE_HOME=$ORACLE_BASE/product/10.2.0  
  5. export NLS_LANG=American_America.ZHS16CGB231280  
  6. export PATH=$ORACLE_HOME/bin:$PATH  
  7. DATE=`date +"%Y%m%d"`  
  8. exp parfile=/app/oracle10g/rman_catalog_dmp/exp.par file=/app/oracle10g/rman_catalog_dmp/rman_catalog_$DATE.dmp log=/app/oracle10g/rman_cat  
  9. alog_dmp/rman_catalog_$DATE.log  
  10. you have mail in /var/mail/oracle 

 

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

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

【编辑推荐】

  1. Oracle临时表在实际开发中的应用详解
  2. Oracle 11g R2数据库示例用户安装说明
  3. Oracle 11g数据库审计功能应用实例解析
  4. Oracle 11g数据库默认审计选项说明详解
  5. Oracle 11g数据库使用XML Table的BUG解决
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2009-07-07 13:44:35

JDK环境变量设置

2011-05-31 13:41:50

Android 环境变量

2009-06-15 16:28:30

JAVA环境变量

2009-07-07 13:10:45

JDK1.6安装

2009-07-03 16:13:10

JSP环境变量

2010-04-27 18:30:42

AIX系统

2009-07-07 12:48:29

JDK环境变量设置

2019-09-09 09:02:04

Linux脚本语言文本编辑器

2009-10-21 12:58:18

2010-09-16 15:33:48

Java环境变量

2010-07-26 15:50:03

Perl脚本语言

2010-11-26 15:56:23

mysql环境变量

2011-08-22 15:06:19

linux环境变量

2009-12-25 09:44:59

redhatPATH设置环境变量

2010-10-28 16:31:27

连接oracle

2021-03-04 23:11:59

环境变量Python

2010-01-11 17:39:31

Fedora 8配置J

2010-01-12 15:46:54

Fedora JDK

2010-03-26 12:50:02

CentOS系统

2010-09-16 15:44:12

Java环境变量
点赞
收藏

51CTO技术栈公众号