博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CRONTAB调用备份脚本时要注意环境变量的设置
阅读量:5947 次
发布时间:2019-06-19

本文共 2206 字,大约阅读时间需要 7 分钟。

 

EXP备份是DBA常规操作之一,尤其是10g以前的版本没有EXPDP,所有的逻辑备份都是通过EXP来实现。而将EXP写成SHELL脚本,使之可以调用也并没有什么特别之处。不过如果并非oracle用户执行,而是需要CRONTAB自动允许,那么备份的脚本就有一些要求了。

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

/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中设置了必要的环境变量;第二尽量所有的文件都采用完全路径方式,避免使用相对路径。

PS:我建了几个oracle QQ群,欢迎数据库爱好者加入。 Oracle专家QQ1群:60632593     Oracle专家QQ2群:60618621      Oracle专家QQ3群:23145225

转载地址:http://rcbxx.baihongyu.com/

你可能感兴趣的文章
数值积分中的辛普森方法及其误差估计
查看>>
Web service (一) 原理和项目开发实战
查看>>
跑带宽度多少合适_跑步机选购跑带要多宽,你的身体早就告诉你了
查看>>
广平县北方计算机第一届PS设计大赛
查看>>
深入理解Java的接口和抽象类
查看>>
java与xml
查看>>
Javascript异步数据的同步处理方法
查看>>
iis6 zencart1.39 伪静态规则
查看>>
SQL Server代理(3/12):代理警报和操作员
查看>>
基于事件驱动的DDD领域驱动设计框架分享(附源代码)
查看>>
Linux备份ifcfg-eth0文件导致的网络故障问题
查看>>
2018年尾总结——稳中成长
查看>>
JFreeChart开发_用JFreeChart增强JSP报表的用户体验
查看>>
度量时间差
查看>>
通过jsp请求Servlet来操作HBASE
查看>>
crontab执行shell脚本日志中出现乱码
查看>>
Shell编程基础
查看>>
Shell之Sed常用用法
查看>>
3.1
查看>>
校验表单如何摆脱 if else ?
查看>>