摘要:今天介紹在中使用定時(shí)任務(wù)的兩種方式。添加并啟動(dòng)定時(shí)任務(wù)其它命令顯示當(dāng)前的定時(shí)任務(wù)刪除所有定時(shí)任務(wù)今天的定時(shí)任務(wù)就說(shuō)到這里,有錯(cuò)誤之處,歡迎交流指正
今天介紹在django中使用定時(shí)任務(wù)的兩種方式。
方式一: APScheduler
1)安裝:
pip install apscheduler
2)使用:
from apscheduler.scheduler import Scheduler from django.core.cache import cache # 實(shí)例化 sched = Scheduler() # 每30秒執(zhí)行一次 @sched.interval_schedule(seconds=30) def sched_test(): """ 測(cè)試-定時(shí)將隨機(jī)數(shù)保存到redis中 :return: """ seed = "123456789" sa = [] for i in range(4): sa.append(random.choice(seed)) code = "".join(sa) cache.set("test_"+code, code)
3)啟動(dòng)定時(shí)任務(wù)
# 啟動(dòng)定時(shí)任務(wù) sched.start()
方式二: django-crontab
1) 安裝:
pip install django-crontab
2) 添加配置到INSTALL_APPS中
INSTALLED_APPS = (
"django_crontab",
)
3) 編寫(xiě)定時(shí)函數(shù):
在django的app中新建一個(gè)test_crontab.py文件,把需要定時(shí)執(zhí)行的代碼放進(jìn)去
import random from django.core.cache import cache def test(): """ 測(cè)試-定時(shí)將隨機(jī)數(shù)保存到redis中 :return: """ seed = "123456789" sa = [] for i in range(4): sa.append(random.choice(seed)) code = "".join(sa) cache.set("test_"+code, code)
4)編寫(xiě)定時(shí)命令
Django為項(xiàng)目中每一個(gè)應(yīng)用下的management/commands目錄中名字沒(méi)有以下劃線開(kāi)始的Python模塊都注冊(cè)了一個(gè)manage.py命令, 自定義一個(gè)命令如下: 必須定義一個(gè)繼承自BaseCommand的Command類, 并實(shí)現(xiàn)handle方法。
編寫(xiě)appname/management/commands/test.py文件
import random from django.core.management.base import BaseCommand from django.core.cache import cache class Command(BaseCommand): """ 自定義命令 """ def handle(self, *args, **options): """ 自定義命令 :return: """ seed = "123456789" sa = [] for i in range(4): sa.append(random.choice(seed)) code = "".join(sa) cache.set("test_"+code, code)
定義完成后,執(zhí)行python manage.py test, 會(huì)執(zhí)行handle()函數(shù)
5) 在settings.py中增加配置
# 運(yùn)行定時(shí)函數(shù) CRONJOBS = [ ("*/1 * * * *", "appname.test_crontab.test",">>/home/python/test_crontab.log") ] # 運(yùn)行定時(shí)命令 CRONJOBS = [ ("*/1 * * * *", "django.core.management.call_command", ["test"], {}, ">> /home/python/test.log"), ]
上面主要有3個(gè)參數(shù),分別表示: 定時(shí)任務(wù)執(zhí)行時(shí)間(間隔), 待執(zhí)行定時(shí)任務(wù), 將定時(shí)任務(wù)的信息追加到文件中
對(duì)于熟悉linux中定時(shí)任務(wù)crontab的同學(xué)可能對(duì)上面第一個(gè)參數(shù)的語(yǔ)法很親切。上面表示每隔1分鐘執(zhí)行一次代碼。
linux中的定時(shí)任務(wù)crontab的語(yǔ)法如下:
* * * * * command 分鐘(0-59) 小時(shí)(0-23) 每個(gè)月的哪一天(1-31) 月份(1-12) 周幾(0-6) shell腳本或者命令
例子:
0 6 * * * commands >> /tmp/test.log # 每天早上6點(diǎn)執(zhí)行, 并將信息追加到test.log中 0 */2 * * * commands # 每隔2小時(shí)執(zhí)行一次
有興趣的小伙伴可以深入研究下linux的crontab定時(shí)任務(wù)。
6) 添加并啟動(dòng)定時(shí)任務(wù)
python manage.py crontab add
其它命令:
python manage.py crontab show: 顯示當(dāng)前的定時(shí)任務(wù) python manage.py crontab remove: 刪除所有定時(shí)任務(wù)
今天的定時(shí)任務(wù)就說(shuō)到這里,有錯(cuò)誤之處,歡迎交流指正!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/42510.html
Python中的功能還是相當(dāng)?shù)亩嗟?,比如,?huì)涉及到使用Django定時(shí)任務(wù),在工作當(dāng)中,它的用途是比較的多的,其中,測(cè)試工程師用到這種的功能是比較多,所以我們要去進(jìn)行詳細(xì)的了解下,下面就給大家詳細(xì)的解答下?! ≡谑褂玫膁jango做測(cè)試平臺(tái)時(shí),,多多少少都會(huì)遇到需要定時(shí)任務(wù)的功能,比如定時(shí)執(zhí)行任務(wù),檢查訂單之類的??赡苁且欢螘r(shí)間,比如每隔10分鐘執(zhí)行一次,也可能是定點(diǎn)時(shí)間,比如14:00執(zhí)行,...
摘要:在這里的腳本有,部署到預(yù)發(fā)布生產(chǎn)服務(wù)器,清理目錄,壓縮,備份數(shù)據(jù)庫(kù),在本地,等等。目錄存儲(chǔ)了所有數(shù)據(jù)庫(kù),,,,等等的配置文件。我使用做所有的排序任務(wù),從發(fā)送郵件到從拉取數(shù)據(jù)。當(dāng)我第一次開(kāi)始開(kāi)發(fā)和的時(shí)候,我使用,但是已經(jīng)把所有事情移植進(jìn)了。 本文原文是 11 Things I Wish I Knew About Django Development Before I Star...
摘要:結(jié)論執(zhí)行完任務(wù)不釋放內(nèi)存與原一直沒(méi)有被銷毀有關(guān),因此可以適當(dāng)配置小點(diǎn),而任務(wù)并發(fā)數(shù)與配置項(xiàng)有關(guān),每增加一個(gè)必然增加內(nèi)存消耗,同時(shí)也影響到一個(gè)何時(shí)被銷毀,因?yàn)槭蔷鶆蛘{(diào)度任務(wù)至每個(gè),因此也不宜配置過(guò)大,適當(dāng)配置。 1.實(shí)際使用 ? 監(jiān)控task的執(zhí)行結(jié)果:任務(wù)id,結(jié)果,traceback,children,任務(wù)狀態(tài) ? 配置 backend=redis://127...
摘要:介紹應(yīng)用舉例是一個(gè)基于開(kāi)發(fā)的分布式異步消息任務(wù)隊(duì)列,通過(guò)它可以輕松的實(shí)現(xiàn)任務(wù)的異步處理,如果你的業(yè)務(wù)場(chǎng)景中需要用到異步任務(wù),就可以考慮使用你想對(duì)臺(tái)機(jī)器執(zhí)行一條批量命令,可能會(huì)花很長(zhǎng)時(shí)間,但你不想讓你的程序等著結(jié)果返回,? celery 1.celery介紹 1.1 celery應(yīng)用舉例 Celery 是一個(gè) 基于python開(kāi)發(fā)的分布式異步消息任務(wù)隊(duì)列,通過(guò)...
閱讀 1545·2023-04-26 00:20
閱讀 1135·2023-04-25 21:49
閱讀 817·2021-09-22 15:52
閱讀 590·2021-09-07 10:16
閱讀 981·2021-08-18 10:22
閱讀 2678·2019-08-30 14:07
閱讀 2248·2019-08-30 14:00
閱讀 2664·2019-08-30 13:00