问题场景
在python虚拟环境中,执行一个语义分析的程序 ./commentAnalysis.sh ,需要每隔10分钟执行一次!结果发现手动执行该脚本,完全没问题,但是呢,一放到crontab定时器就不执行了?这是为什么呢?
问题排查
在linux shell中手动执行 env , 显示出来一堆已经加载的环境变量; 然后写一个脚本 执行 env命令,放在crontab 定时器中执行,发现输出的环境变量和手动在shell执行的环境变量不一致。后来查明原因,是因为crontab定时器不会加载用户环境变量导致。
查看报错
crontab定时器任务的执行日志,可以通过mail邮件查看,执行命令 : tail -f /var/mail/username即可实时查看报错日志。
解决方案
1.加载用户环境变量方式:
0 */10 * * * source ~/.bashrc; /home/hadoop/demo.sh
2.加载python虚拟环境方式:
0 */10 * * * sh -c ". /home/username/tf_venv/bin/activate;sh /home/username/commentAnalysis.sh"