shell脚本内环境变量问题

来源:互联网 发布:linux matlab库 编辑:程序博客网 时间:2024/06/10 05:55

今天想写一脚本,定时执行一个jar包,脚本内容如下:


#!/bin/sh

nohup java -jar /var/job/testj.ar abc &

exit 0


脚本很简单,但执行的时候却出问题了。单独通过./test.sh执行没有问题,但当配置到crontab中作为定时任务跑的时候,问题出来了,程序没有运行(没有任何输出)。调试过程中配置的每分钟执行一次。


开始以为是crontab的调度出问题了,在脚本中增加了一日志输出,如下:

#!/bin/sh

ehco "aaa" > /var/job/1.log

nohup java -jar /var/job/testj.ar abc &

exit 0


再保存等待一分钟后查看,1.log文件正常生成了,crontab的服务没有问题。

查了下crontab任务失败的几种常见的原因,其中一个就是环境变量引起的,crontab调度的shell脚本运行时,shell脚本使用到的环境变量和我们直接执行shell脚本时的环境变量会有差异,于是调整脚本数据看了下:

#!/bin/sh

ehco $PATH> /var/job/1.log

nohup java -jar /var/job/testj.ar abc &

exit 0


任务执行后,查看1.log的内容,果然和直接在命令行使用echo $PATH的输出不一致,压根没有java的环境变量配置,难怪不执行了。

于是解决方案如下,在shell脚本最前面,将当前用户的环境变量导入,修改后如下:

#!/bin/sh

source /etc/profile

nohup java -jar /var/job/testj.ar abc &

exit 0


保存退出,定时任务再次运行后,jar包正常运行。



0 0
原创粉丝点击