av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

python - celery beat 調度如何運行期間動態添加任務?

瀏覽:114日期:2022-07-10 15:29:13

問題描述

我嘗試過django-celery-beat,在admin后臺添加任務,可以實現動態添加任務但要重啟celery beat才生效,請問,有其他方試嗎?

問題解答

回答1:

無法動態添加,必須重啟 beat。

ask 回答過原因了 #3493

回答2:

有個思路,你可以考慮,我目前也在嘗試這個方法,處于摸石過河階段。celery是支持定時任務,但是不符合我的需求,我需要像linux下的crontab這樣動態添加定時任務,我也看了django-celery-beat,因為用的是Flask,發現不值得參考實現,所以一直在看文檔搜資料,終于被我找到一種方式,celery的apply_async這個函數非常有用,它有個eta參數,它的簡化使用是countdown,但是eta的威力是很巨大的,因為它只接受datetime對象,比如你給定一個任務在2017-05-02 20:0:0執行,你可以這樣使用:

job.apply_async(args=args, kwarg=kwargs, eta=datetime(2017,5,2,20,0,0))

是不是很少用,假如我有一個任務需要每天晚上八點執行,我可以利用這個eta參數實現。偽代碼如下:

時間規則 = ’每天晚上八點執行’第一次調用任務,先計算最近的執行時間,作為eta的參數,調用apply_async函數,然后第一次任務執行成功,得到上次任務的eta參數值,在天的值上加一,然后把新的執行時間作為eta的參數再次調用apply_async函數,這里省略了很多判斷,自行腦補。循環往復,是不是一直按每天晚上八點執行。

這里有個非常重要的點是如何在任務執行成功的時候計算下一次的執行時間,做法如下

class MyTask(Task): def on_success(self, retval, task_id, args, kwargs):print ’task done: {0}’.format(retval)return super(MyTask, self).on_success(retval, task_id, args, kwargs) def on_failure(self, exc, task_id, args, kwargs, einfo):print ’task fail, reason: {0}’.format(exc)return super(MyTask, self).on_failure(exc, task_id, args, kwargs, einfo)@app.task(base=MyTask)def add(x, y): return x + y

它提供了任務執行成功和失敗的函數,我們只要在此基礎上重寫就可以了,我說的只是最核心的部分,具體怎么做有很多方法,

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 午夜激情福利视频 | 国产一区二区在线播放 | 成人小视频在线 | 日韩黄色一级片 | 性视频在线 | 国产成人97精品免费看片 | www.超碰在线 | 精品视频一区二区三区 | 成人永久免费视频 | 香蕉综合网 | 欧美日韩国产在线 | 伊人精品在线 | aaaaaabbbbbb毛片 | 可以免费看黄的网站 | 亚洲综合在线播放 | 狠狠干 | 少妇综合| 日韩av不卡在线观看 | 国产欧美一区二区精品忘忧草 | 久青草视频 | 五月综合色 | 长河落日连续剧48集免费观看 | 大尺度做爰呻吟舌吻网站 | h片在线观看免费 | 免费看黄色录像 | 一区二区网站 | 欧美日韩精品久久久免费观看 | 综合导航| 久久99久久久 | 久久av在线| 欧美成人a| 永久免费看mv网站入口亚洲 | 黄色xxxxx | 国产激情一区二区三区 | 成人免费福利视频 | 亚洲精品www| 日韩欧美视频一区 | 亚洲精品乱码久久久久久蜜桃91 | 日韩黄色一级视频 | 国产在线日韩 | 性久久久久久久 |