这两天一直在忙于将一项任务全自动化,以便节省人工操作,由于服务器是linux,用到了crontab命令,具体命令大致如下:
46 21 * * * night_job.sh>>night_job.log 2>&1
为了便于跟进查询运行状态和日志,将任务的输出重定向到night_job.log日志中,由于在night_job.sh中包含了
数量众多的sqlldr:sqlloader导入命令和sqlplus命令,开始测试时并未得到预期的结果,通过日志观察到
line 136: sqlldr: command not found
line 1: sqlplus: command not found
而当前用户的PATH环境变量中已经包含了$ORACLE_HOME/bin,按理说应该读取到,推测是可能是crontab命令并没有初始化当前用户下的环境变量导致。
综合了网上的其他文章,通过如下几种方式解决:
1、将.bash_profile中的设置拷贝到crontab执行的脚本中
2 、在crontab执行的shell脚本先执行./bash_profile
3、source dir/.bash_profile
以上三种处理方式中
1最繁琐,如果用户下增加环境变量设置,可能仍然需要修改该脚本
2相对简单些,但是./执行要切换到用户根目录执行,在执行其他脚本之前要确保路径是否正确
3最简单,直接加载环境变量即可
按照3中的方式在其他任务运行之前加入该命令,任务运行成功。问题解决。
crontab定时任务环境变量丢失问题
精选 转载guojianrui 博主文章分类:linux实验
文章标签 crontab定时任务环境变量丢失问题 文章分类 运维
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
设置定时任务,别再写死了!动态定时任务真的太爽了!
设置定时任务,别再写死了!动态定时任务真的太爽了!
spring 触发器 cron表达式 -
【Linux】定时任务 | crontab定时任务
crontab –e2、自行添加命令0 1 * * * sh /opt/r...
linux 运维 centos 加载 重启