1

我在我的代码中这样做

ssh -q username@ip 'crontab -l' > $PWD/crontab.txt

如果服务器有crontab,则没有问题,它可以工作。但是,如果该服务器没有 crontab,我会收到消息no crontab for username

有没有办法禁用此消息?当没有 crontab 时,我不希望它输出任何内容。

提前致谢

4

1 回答 1

0

我知道这是一篇较旧的帖子,但我也一直在为此苦苦挣扎,直到现在才找到令人满意的答案。我想禁止显示此消息的原因是我正在编写一个脚本,该脚本还使用以下行向 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。

于 2021-01-20T16:07:22.910 回答