1:Celery简介
1.1 异步任务,假设用户发起一个request,并等待request返回。但是在request 经过django一层层处理到达我们的view时,view要进行一次比较耗时的操作,比如分析日志文件或者发起一个http请求。这些操作耗时无法确定,这样我们的API接口的响应时间就无法预知了。为了给用户以良好的体验,我们应该把这种耗时的任务放在后台处理。
1.2 定时任务,之前遇到一个需求是这样的。根据Django的日志数据分析用户的访问习惯和页面访问次数。这种任务不可能在用的时候再去分析统计,那肯定来不及了。所以需要在每天零点整自动分析这些日志。当遇到这种问题时我们可以采用Celery的定时任务。当然还有另一种解决方案,自定义Django Command 然后用shell脚本执行。然后添加到系统定时任(crontab)务里。
2:在本系统中的应用有两点
(1)中毒IP自动控制(定时任务)
(2)在通过黑名单页面手动恢复IP通信(异步任务)