向 cron 添加任务以运行 sh 文件。该文件属于具有权限 644 的 root-root。如果没有任何更改,则不执行脚本 - 没有权限。
或者,您可以设置文件 755 的权限 - 然后一切正常。也许不更改权限更正确,而是通过更改文件的所有者和组来更改文件的所有权?
我搜索但找不到将这些权限转移给哪个用户以便 cron 脚本运行。操作系统 - Linux Debian 10。
//////////////////////
谢谢大家的参与!
在脚本名称前添加/bin/bash解决了启动问题,而无需将文件属性从 644 更改为 755。
从任何人。
每个用户都有自己的一组 cron 任务。cron 守护程序代表以下用户之一运行任务(脚本):root、普通用户或系统用户。
crontab -l
- 获取当前用户的任务sudo crontab -l -u mysql
- 获取另一个用户的任务,在本例中为 mysql。由于您以普通用户身份登录,而普通用户无法查看/编辑其他用户的任务,因此有必要root
通过sudo
.sudo su
,crontab -l -u mysql
- 一样,只是我们先登录下root
sudo cat /etc/crontab
- 显示系统 cron 任务。在这个文件中,与通常的 cron 不同,有一个列user
- 将从哪个用户启动任务。并且普通用户不能编辑这个文件,只有root可以编辑。/etc
:中也有这样的目录cron.d/
cron.daily/
cron.hourly/
cron.monthly/
cron.weekly/
,它们是用于系统任务的,您自己查看内容。用户也在那里注册。脚本未执行,因为未设置执行属性。您需要决定将此属性放在哪个级别 - 所有者、组或所有人。假设一个文件具有属性 644 和 owner:group root:root。
要运行脚本,您需要
chmod u+x
或chmod 764
- 对于所有者(根)chmod g+x
或chmod 674
- 对于组(根)chmod o+x
或chmod 665
- 对于其他所有人该脚本接收与代表其运行的用户相同的权限/特权。这意味着他将有权访问/创建来自同一用户的文件,以及执行其他任务/脚本。
一般来说,是的。但我建议你弄清楚它是如何工作的:cron、sudo、访问权限。搁置紧急任务,阅读,然后返回。并且您将了解 Linux 系统的美妙之处 :)