crontab定时任务环境变量丢失问题

这两天一直在忙于将一项任务全自动化,以便节省人工操作,由于服务器是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定时任务环境变量丢失问题)