我在我的代码中这样做
ssh -q username@ip 'crontab -l' > $PWD/crontab.txt
如果服务器有crontab
,则没有问题,它可以工作。但是,如果该服务器没有 crontab,我会收到消息no crontab for username
。
有没有办法禁用此消息?当没有 crontab 时,我不希望它输出任何内容。
提前致谢
我知道这是一篇较旧的帖子,但我也一直在为此苦苦挣扎,直到现在才找到令人满意的答案。我想禁止显示此消息的原因是我正在编写一个脚本,该脚本还使用以下行向 crontab 添加了一行,并为用户提供了我自己的自定义输出:
CRON_LINE='0 0 1 * * /path/to/my_script.sh'
(crontab -u antiftw -l; echo "$CRON_LINE" ) | crontab -u antiftw -
我尝试在第二行的末尾添加通常的重定向(如评论中所述),但这些都没有抑制消息:
2> /dev/null
>> /dev/null 2>&1
因此,经过一番环顾和测试后,我发现显示此消息的原因是存储 crontab 的位置没有文件。在 Ubuntu 20.04 中,这是:
/var/spool/cron/crontabs/
此文件具有我们为其创建 crontab 的用户的名称:
/var/spool/cron/crontabs/root 用于 root 用户
或者
/var/spool/cron/crontabs/antiftw 用于用户“antiftw”
因此,如果我们想为用户“antiftw”创建一个 crontab,我们使用以下命令在此位置创建一个空文件:
touch /var/spool/cron/crontabs/antiftw
在此之后,重要的是为此文件提供正确的所有者/组和文件权限,否则在尝试使用 crontab 命令修改 crontab 时会出现以下错误:
crontab:crontabs/antiftw:重命名:不允许操作
所以我们执行以下命令:
chmod 600 /var/spool/cron/crontabs/antiftw
chown antiftw:crontab /var/spool/cron/crontabs/antiftw
注意:如果我们想为 root 用户执行此操作,则更改为:
chmod 600 /var/spool/cron/crontabs/root
chown root:crontab /var/spool/cron/crontabs/root
产生以下权限:
-rw------- 1 antiftw crontab
现在我们已经准备好文件,我们可以添加我们的 cron-lines 而不会收到消息。要检查是否已正确添加行,我们可以使用:
crontab -l
这将产生最近添加的 cronline。