django_cron奇怪的台词



我 http://django-cron.readthedocs.org/en/latest/installation.html 使用此指令,无法理解"唯一代码"行的含义。

from django_cron import CronJobBase, Schedule
class MyCronJob(CronJobBase):
    RUN_EVERY_MINS = 120 # every 2 hours
    schedule = Schedule(run_every_mins=RUN_EVERY_MINS)
    code = 'my_app.my_cron_job'    # a unique code
    def do(self):
        pass    # do your thing here

谁能解释一下这条线的作用?

code = 'my_app.my_cron_job'    # a unique code

查看此处的代码:

def make_log(self, *messages, **kwargs):
    cron_log = self.cron_log
    cron_job      = getattr(self, 'cron_job', self.cron_job_class)
    cron_log.code = cron_job.code

我们可以理解,这个"唯一代码"表示特定的 cron 任务。每次执行 cron 任务时,都会使用 cron_log.code = cron_job.code 创建CronJobLog实例。

因此,可以过滤属于特定任务的日志:

last_job = CronJobLog.objects.filter(code=cron_job.code).latest('start_time')

这就是为什么它必须是唯一的,不要将一个 cron 任务的日志与另一个 cron 任务混合。我想它与 id 具有相同的目的,但这段代码具有有意义的价值。

相关内容

  • 没有找到相关文章

最新更新