今天想写一脚本,定时执行一个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包正常运行。