为什么 cron.daily 中的这个脚本不会运行?

lve*_*lla 3 linux ubuntu cron

我编写了这个小的 Python 脚本来对包含一些文件的目录进行每日备份(备份应该在一周后轮换)。就是这个:

$ cat /etc/cron.daily/file-store-backup.py
#!/usr/bin/python3

import datetime
import calendar
import subprocess
import os.path

def main():
    origin = '/var/file-store'
    today_name = calendar.day_name[datetime.date.today().weekday()]
    dest = '/var/file-store-backup/' + today_name

    if os.path.exists(dest):
        subprocess.call(['rm', '-rf', dest])

    subprocess.call(['cp', '--reflink=always', '-a', origin, dest])
    subprocess.call(['touch', dest])

    last = open('/var/file-store-backup/LAST', 'w')
    print(today_name, file=last)

if __name__ == "__main__":
    main()
Run Code Online (Sandbox Code Playgroud)

当我手动运行它时,它按预期工作,创建了一个以当前星期日命名的备份目录,但它不是每天运行:我将它留在 /etc/cron.daily 中 3 天,之后没有创建备份目录,服务器一直在运行。

权限是正确的:

$ ls -l /etc/cron.daily/file-store-backup.py 
-rwxr-xr-x 1 root root 553 Abr 11 17:19 /etc/cron.daily/file-store-backup.py
Run Code Online (Sandbox Code Playgroud)

系统为Ubuntu Server 12.04.2 LTS,安装后cron配置没有被篡改。

为什么脚本没有运行?

use*_*517 11

发生这种情况是因为您的脚本有.py扩展名。中的文件/etc/cron.dailyrun-parts(8)命令运行,默认情况下忽略不匹配各种规则的程序。您应该能够删除.py扩展程序。

run-parts 运行在下面描述的约束中命名的所有可执行文件,在目录目录中找到。其他文件和目录将被静默忽略。

如果 --lsbsysinit 选项和 --regex 选项都没有给出,则名称必须完全由 ASCII 大写和小写字母、ASCII 数字、ASCII 下划线和 ASCII 减号连字符组成。

例如

touch /etc/cron.daily/test.py
chmod +x /etc/cron.daily/test.py
run-parts --test /etc/cron.daily
/etc/cron.daily/apache2
...
Run Code Online (Sandbox Code Playgroud)

没有test.py的迹象

mv /etc/cron.daily/test.py /etc/cron.daily/test
run-parts --test /etc/cron.daily 
/etc/cron.daily/apache2
...
/etc/cron.daily/test
Run Code Online (Sandbox Code Playgroud)

达达!