cron 执行任务不成功
- 0次
- 2021-06-28 05:30:12
- idczone
vps 上 root 用户安装了程序 aa,并登陆 aa 的帐号(首次要登陆,以后不用登陆)
直接登陆 vps 终端,root 用户下执行 aa --help | grep url >> /home/a/a.log 成功,测试好后把文件删除。
再写在 crontab 里就执行失败了,虽然它建立了文件 /home/a/a.log ,但文件为空,意味着 cron 下执行的 aa 没有登陆,所以没有输出?
另外测试了一下 cron 执行 whoami >> /home/a/ab.log ,看到 cron 的用户是 root
怎么解决
如果这程序一定要用它自己的 uid 来运行的话,你得在系统级的 crontab 里指定 uid,或者干脆以这个 uid 登录后添加用户级 crontab。。。
计划任务改成 sudo -u aa 呗
联想能力真丰富,你怎么就“意味着没登录”了?
你还没说你那个 aa 程序内是啥功能呢
通过 geteuid、环境变量、getlogin、读 utmp 等方式获得到的身份信息 *不一定* 相同
chmod +x aa, 另外加上环境 path
程序就是 openshift v3 的 oc,帖子里的命令是乱写的不用理会,登陆后它会建立配置目录 /root/.kube,里面有很多文件和目录,有一个文件里有登陆信息,包括用户名和 token 等
直接用绝对路径来执行命令,就像这样:
/path/to/aa --help | /path/to/grep url >> /home/a/a.log
真的是路径问题,可是我已经在 /root/.bashrc 里添加了 path。。。
问题是那个文件是给 bash 用的,你这里并没有用到 bash 吧?
现在 shell 中执行保证没问题然后配置到 crontab,写 log 要这样
xxx.sh >> log.txt 2>&1
后面的是把 stderr 重定向到 stdout,再将 stdout 的内容重定向到文件里。
而很明显,lz 的问题是程序 aa 正常运行时有 stdout 输出的,但是在 cron 中连 stdout 输出都没有。所以你的说法不对。
是不是要改全局配置
cat /etc/profile 看看
vi /etc/profile.d/custom.sh
加路径
crontab 的 PATH 应该加在 /etc/crontab 中,直接在最前面加:
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
谢谢指点,以前不知道要写这里
profile 不是全局配置。Linux 里基本上没有“全局配置”这个概念
profile 是给“登录 shell ”用的初始化文件
echo $PATH