技术解析

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

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服