1. 如果是sh脚本:
直接在脚本前面加上: source /etc/profile
2. 如果是python:
source /etc/profile && python /mypath/myscript.py ...
原因:crontab 不能自动从用户profile文件中读取环境变量参数。具体解释
如果没有生效,可以重启crontab服务,/etc/init.d/crond restart ; 参考网页
如果依然无法解决问题那么需要查看你的文件编码是否有问题:
在执行shell脚本时提示这样的错误主要是由于shell脚本文件是dos格式,即每一行结尾以\r\n来标识,而unix格式的文件行尾则以\n来标识。
查看脚本文件是dos格式还是unix格式的几种办法。
(1)cat -A filename 从显示结果可以判断,dos格式的文件行尾为^M$,unix格式的文件行尾为$。
(2)od -t x1 filename 如果看到输出内容中存在0d 0a的字符,那么文件是dos格式,如果只有0a,则是unix格式。
(3)vi filename打开文件,执行 : set ff,如果文件为dos格式在显示为fileformat=dos,如果是unxi则显示为fileformat=unix。
解决方法:
(1)使用linux命令dos2unix filename,直接把文件转换为unix格式
(2)使用sed命令sed -i "s/\r//" filename 或者 sed -i "s/^M//" filename直接替换结尾符为unix格式
(3)vi filename打开文件,执行 : set ff=unix 设置文件为unix,然后执行:wq,保存成unix格式。
注意如果直接执行shell脚本,而放到定时任务中不成功,此时需要查看定时任务执行日志,如下命令可输出定时任务执行日志(./etc/profile; 为引入环境变量):
*/5 * * * * ./etc/profile;/bin/sh /opt/bak.sh -> /opt/execronlog.txt 2>&1 &
查看日志cat /opt/execronlog.txt:
the input device is not a TTY
若使用docker:
#!/bin/bash
source /etc/profile
docker exec -it 3473faa6479a mysqldump -uroot -p1qaz@WSX oa > /data/mysql/backup/oa_$(date +"%Y%m%d%H%M%S").sql
改为 docker exec -i 3473faa6479a mysqldump -uroot -p1qaz@WSX oa > /data/mysql/backup/oa_$(date +"%Y%m%d%H%M%S").sql