linux crontab 定时任务执行脚本时环境变量没有加载的问题

本文分析了一起Crontab定时任务执行失败案例,详细介绍了因环境变量未正确加载导致的问题,并提供了两种解决方案:一是在执行命令前加入source /etc/profile命令;二是修改脚本,在执行逻辑前加载环境变量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近发现现场每天重启程序的定时任务没有成功执行,在程序的启动日志中并没有打印定时任务执行时间点的日志信息。

查看 /var/log/cron 日志,发现定时任务已执行。

查看 /var/spool/mail/root 日志,发现脚本执行报错,没有找到环境变量。

查询了想关资料,发现crontab执行定时任务时不会缺省的从用户profile文件中读取环境变量参数,导致脚本执行失败。

解决方法:

       1. 在添加定时任务时,在执行脚本的命令前加上   source /etc/profile  &&   ,先加载环境变量,再执行脚本

       2.修改脚本,在执行逻辑之前执行  source /etc/profile  命令即可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值