crontab 定时执行脚本出错,但手动执行脚本正常

原因: crontab 没有去读环境变量,需要再脚本中手动引入环境变量,可以用source 也可以用export 写死环境变量。

案例:

    用crontab定时执行一个脚本,这个脚本完成执行java程序的功能; 在用sh 手动执行脚本时能正常执行,但是用crontab定时器手动执行就没有输出。

 1) 后来查看定时任务,没有将错误输出打印到日志中,需要加上 2>&1;

 2) 脚本中没有设置java环境变量,导致提示:Unsupported major.minor version 51.0; 后来引入java环境变量,定时任务就能执行成功了。

 https://www.cnblogs.com/gmq-sh/p/6971588.html 也可通过这里面用source将环境变量配置文件引入。

 

crontab的任务执行日志可以在 /var/spool/mail/.. 下面查看;

* * * * *  sh /home/test.sh | tee -a /home/test.log 2>&1 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值