内容简介:django提供了commands类,允许我们编写命令行脚本,并且可以通过python manage.py拉起。具体django commands如何使用,大家参考官方文档即可:使用时遇到一个坑:在commands运行中的异常并不会打印到屏幕上,它要求我们必须抛出CommandError类型的异常才能被打印到屏幕中,具体参考:
django提供了commands类,允许我们编写命令行脚本,并且可以通过python manage.py拉起。
了解commands
具体django commands如何使用,大家参考官方文档即可: https://docs.djangoproject.com/en/2.2/howto/custom-management-commands/
一个坑
使用时遇到一个坑:在commands运行中的异常并不会打印到屏幕上,它要求我们必须抛出CommandError类型的异常才能被打印到屏幕中,具体参考: https://docs.djangoproject.com/en/2.2/howto/custom-management-commands/#command-exceptions
文件锁防并发
我们通常利用Crontab拉起定时任务,那么就会面临一个常见问题,如何避免前一次没结束而后一次再次启动的问题。
通常都是用文件锁来搞定这个事情,我做了一个简单的装饰器来包装Commands的handle方法,定义一套元类或者类装饰器都可以达到同样的目的,这里就不炫技了。
# -*- coding: utf-8 -*- import fcntl import os from apps.settings import CRON_LOCK_DIR # 尝试加锁 def try_lock(name): def decorator(func): def wrap(*args, **kwargs): os.makedirs(CRON_LOCK_DIR, exist_ok=True) with open('{}/{}'.format(CRON_LOCK_DIR, name), 'w') as fd: try: fcntl.lockf(fd, fcntl.LOCK_EX | fcntl.LOCK_NB) # 加锁 func(*args, **kwargs) fcntl.lockf(fd, fcntl.LOCK_UN) # 解锁 except: # 加锁异常跳过 pass return wrap return decorator
其中CRON_LOCK_DIR是文件锁的父目录,下面放了若干锁文件。
对Commands的handle方法指定锁文件名即可:
class Command(BaseCommand): @try_lock('check_order') # 指定锁文件的名字 def handle(self, *args, **options): pass
本篇博客就讲这些。
博主无私的分享着知识,你愿意送他一顿热腾腾的早餐吗?
以上所述就是小编给大家介绍的《Django 防止定时任务并发》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Linux内核设计与实现
拉芙 / 陈莉君、唐华、张波 / 机械工业出版社 / 2006-1 / 38.00元
《Linux内核设计与实现》基于Linux2.6内核系列详细介绍Linux内核系统,覆盖了从核心内核系统的应用到内核设计与实现等各方面的内容。主要内容包括:进程管理、系统调用、中断和中断处理程序、内核同步、时间管理、内存管理、地址空间、调试技术等。本书理论联系实践,既介绍理论也讨论具体应用,能够带领读者快速走进Linux内核世界,真正开发内核代码。 本书适合作为高等院校操作系统课程的教材......一起来看看 《Linux内核设计与实现》 这本书的介绍吧!