成人伊人青草久久综合网_91在线视频免费观看_毛片免费视频网站_亚洲欧美日韩在线中文字幕

celery筆記一之celery介紹、啟動和運(yùn)行結(jié)果跟蹤-環(huán)球熱文

來源:博客園

本文首發(fā)于公眾號:Hunter后端原文鏈接:celery筆記一之celery介紹、啟動和運(yùn)行結(jié)果跟蹤


【資料圖】

本篇筆記內(nèi)容如下:

celery 介紹celery 準(zhǔn)備celery 啟動和異步任務(wù)的運(yùn)行運(yùn)行結(jié)果跟蹤1、celery 介紹

celery 大致有兩種應(yīng)用場景,一種是異步任務(wù),一種是定時任務(wù)。

比如說在一個接口請求中,某個函數(shù)執(zhí)行所需的時間過長,而前端頁面并不是立刻需要在接口中獲取處理結(jié)果,可以將這個函數(shù)作為異步任務(wù),先返回給前端處理中的信息,在后臺單獨(dú)運(yùn)行這個函數(shù),這就是異步任務(wù)。

另一個比如說某個函數(shù)需要每天晚上運(yùn)行一遍,不可能人天天守著后臺手動執(zhí)行一遍這個函數(shù),那么就可以用 celery 來實(shí)現(xiàn)這個定時的周期任務(wù)。

接下來介紹一下 celery 的組成:

task

這個任務(wù)就是我們前面舉的例子的異步任務(wù)或者是定時任務(wù),即為 task,我們可以定義這些任務(wù),然后發(fā)送到 broker

broker

broker 可以理解成消息中間件,用于獲取異步或者定時任務(wù),形成一個或多個消息隊(duì)列,然后發(fā)送給 worker 處理這些消息

broker 的形式可以是 Redis,RabbitMQ 或者其他,這里我們使用 Redis 作為消息中間件

worker

worker 是處理消息的程序,獲取 broker 中的消息,然后在 worker 中執(zhí)行,然后根據(jù)配置決定將處理結(jié)果發(fā)送到 backend

result_backend

在 worker 處理完消息之后會有 return 或者沒有返回結(jié)果,都會根據(jù)配置將結(jié)果發(fā)送出來,可以配置成發(fā)送到 redis 中,也可以將之存儲到 database 中

beat

主要用于調(diào)用定時任務(wù),根據(jù)設(shè)定好的定時任務(wù),比如每天晚上十點(diǎn)執(zhí)行某個函數(shù),beat 則會在相應(yīng)的時間將這個 task 發(fā)送給 broker,然后 worker 獲取任務(wù)進(jìn)行處理

定時任務(wù)除了說的每天晚上十點(diǎn)這種周期任務(wù),也可以是間隔任務(wù),比如說每隔多少秒,多少分鐘執(zhí)行一次

注意:異步任務(wù)的發(fā)送是不經(jīng)過 beat 處理,直接發(fā)送給 broker 的

在上面的結(jié)構(gòu)中,broker 需要將相應(yīng)的服務(wù)比如 redis 運(yùn)行起來,而 worker 和 beat 需要在手動用程序運(yùn)行,而且每次更改了定時策略之后需要重新啟動 beat 和 worker 才能生效。

2、celery 準(zhǔn)備

接下來我們實(shí)現(xiàn)一個最簡單的異步任務(wù),在執(zhí)行異步任務(wù)前,我們做如下的準(zhǔn)備工作

1.安裝依賴

我們需要安裝一下 celery 和 redis 的依賴:

pip3 install celery==5.1.2 -i https://mirrors.aliyun.com/pypi/simple/pip3 install redis==3.5.3 -i https://mirrors.aliyun.com/pypi/simple/
2.消息中間件

這里我們用到的消息中間件是 redis,可以去官網(wǎng)下載一個 redis 啟動,也可以使用 docker 來執(zhí)行安裝。

我在之前的 docker 系列筆記中有介紹過如何拉取鏡像和運(yùn)行容器,我們這里直接使用 docker 來運(yùn)行:

docker run -itd -p 6379:6379 redis:latest
3.異步任務(wù)準(zhǔn)備

我們準(zhǔn)備一個最簡單的 add() 函數(shù),放在 tasks.py 文件中:

# tasks.pyfrom celery import Celeryapp = Celery("tasks", broker="redis://localhost/0", backend="redis://localhost/1")@app.taskdef add(x, y):     return x + y

在這段代碼里,我們引入 Celery 模塊,并將其實(shí)例化為 app,且配置了 broker 參數(shù),表示消息隊(duì)列都會被放在 redis 的第一個數(shù)據(jù)庫下

指定的 backend 參數(shù)則表示函數(shù)運(yùn)行的結(jié)果被放在 redis 的第二個數(shù)據(jù)庫下

然后用 @app.task 修飾 add 函數(shù),表示它是 app 下的 task 任務(wù)

以上,我們的準(zhǔn)備工作就完成了,接下來嘗試運(yùn)行這個異步任務(wù)

3、celery 啟動和異步任務(wù)的運(yùn)行

說是 celery 的啟動,其實(shí)是 worker 的啟動,中間件是 redis,已經(jīng)在前面的步驟中啟動了。

我們在 tasks.py 所在的文件夾下執(zhí)行下面的命令:

celery -A tasks worker -l INFO

在這里,tasks 是我們?nèi)蝿?wù)所在的文件名,worker 表示啟動的是 worker 程序

-l INFO 則會在控制臺打印出 worker 接收到的消息詳情,如果不執(zhí)行,則信息流不會被打印出來

執(zhí)行了上面的程序后,可以看到控制臺會輸出下面這種信息:

-------------- celery@localhost v5.1.2 (sun-harmonics)--- ***** ----- -- ******* ---- Darwin-21.4.0-x86_64-i386-64bit 2022-07-17 23:56:09- *** --- * --- - ** ---------- [config]- ** ---------- .> app:         tasks:0x7fc8ddf3df98- ** ---------- .> transport:   redis://localhost:6379/0- ** ---------- .> results:     disabled://- *** --- * --- .> concurrency: 12 (prefork)-- ******* ---- .> task events: OFF (enable -E to monitor tasks in this worker)--- ***** -----  -------------- [queues]                .> celery           exchange=celery(direct) key=celery                [tasks]  . tasks.add[2022-07-17 23:56:09,685: INFO/MainProcess] Connected to redis://localhost:6379/0[2022-07-17 23:56:09,699: INFO/MainProcess] mingle: searching for neighbors[2022-07-17 23:56:10,737: INFO/MainProcess] mingle: all alone[2022-07-17 23:56:10,780: INFO/MainProcess] celery@localhost ready.

則表示 worker 啟動成功

執(zhí)行異步任務(wù)

在另一個 shell 窗口,進(jìn)入 python 的交互界面,輸入以下命令:

from tasks import addres = add.delay(1,2)

add 是我們需要執(zhí)行的異步任務(wù)的函數(shù)名

delay 是異步任務(wù)執(zhí)行的特有方法,這個其實(shí)是 apply_async() 函數(shù)的簡便寫法,不帶任何參數(shù),apply_async() 除了可以實(shí)現(xiàn)異步任務(wù)的功能,還可以指定多少時間后執(zhí)行,比如說二十秒后執(zhí)行,這個在后面的筆記中我們再介紹。

而異步任務(wù)的返回我們這里用 res 來定義,它是一個包含了這個任務(wù)所有執(zhí)行信息對象,有任務(wù)狀態(tài)(是否執(zhí)行成功),有返回結(jié)果(add() 函數(shù)的return),還有這個 task 特有的標(biāo)識 id等信息

至此,我們的一個異步任務(wù)的執(zhí)行就完成了,我們可以在下一步查看它的運(yùn)行結(jié)果等信息。

4、運(yùn)行結(jié)果跟蹤

接下來,我們在 tasks.py 中建立下面幾個函數(shù),來測試我們對結(jié)果的跟蹤:

# tasks.pyimport timefrom celery import Celeryapp = Celery("tasks", broker="redis://localhost/0", backend="redis://localhost/1")@app.taskdef add(x, y):    return x + y@app.taskdef div(x, y):    return x / y@app.taskdef test_not_finished():    time.sleep(30)    return True

然后重新運(yùn)行 worker:

celery -A tasks worker -l INFO

然后引入和執(zhí)行函數(shù):

from tasks import add, div, test_not_finished

獲取延時任務(wù)的結(jié)果

res = add.delay(1, 2)print(res.result)# 也可以使用 get() print(res.get())

get() 函數(shù)也可以加個超時的設(shè)置:

res.get(timeout=2)

但是這樣需要注意,因?yàn)槿绻瑫r了還未獲取到結(jié)果,程序就會報錯

判斷函數(shù)運(yùn)行是否完成

print(res.ready())

打印出的結(jié)果為 True 則表示函數(shù)運(yùn)行完成

我們可以測試函數(shù)為完成的狀態(tài):

res2 = test_not_finished.delay()

在這個函數(shù)里,我們設(shè)置了 30s 的休眠,所以在 30s 內(nèi)我們打印結(jié)果可以看到 res2.ready() 是為 False 的:

print(res2.ready())

獲取task id

每個被執(zhí)行的 task 都有各自對應(yīng)的 id 作為它們的唯一鍵:

print(res.id)

查看任務(wù)執(zhí)行的狀態(tài)

# 任務(wù)執(zhí)行是否失敗,返回 布爾型數(shù)據(jù)is_failed = res.failed()# 任務(wù)執(zhí)行是否成功,返回布爾型數(shù)據(jù)is_successful = res.successful()# 執(zhí)行的任務(wù)所處的狀態(tài)state = res.state# state 的值會在 PENDING,STARTED,SUCCESS,RETRY,F(xiàn)AILURE 這幾種狀態(tài)中,分別是 待處理中,任務(wù)已經(jīng)開始,成功,重試中,失敗

報錯處理

如果執(zhí)行的延時任務(wù)在程序中報錯,比如我們定義的 div() 函數(shù),我們傳入的除數(shù)為 0 的話,在程序中是會報錯的,我們使用 get() 來獲取結(jié)果的話程序是會報錯的:

res3 = div.delay(3, 0)res3.get()# 返回會報錯

但是我們可以使用 propagate=False 參數(shù)來忽略程序的報錯:

res3.get(propagate=False)

這樣我們獲取的就不是程序報錯,而是程序報錯的信息作為結(jié)果返回

使用 res3.state 發(fā)現(xiàn)返回的結(jié)果是 FAILURE

當(dāng)延時任務(wù)在程序中報錯,它的返回值就不會是正確的,我們可以通過 res3.traceback 是否有值來判斷函數(shù)運(yùn)行過程中是有報錯:

if res3.traceback:    print("延時任務(wù)報錯")else:    print("程序正常運(yùn)行,可以獲取返回值")

result資源釋放

因?yàn)?backend 會使用資源來保存和傳輸結(jié)果,為了確保資源被釋放,所以在執(zhí)行完異步任務(wù)后,你必須對每一個結(jié)果調(diào)用 get() 或者 forget() 函數(shù)

result.get() 函數(shù)獲取結(jié)果

result.forget() 在 backend 刪掉該數(shù)據(jù)

在官方文檔上,意思是 get() 和 forget() 方法都可以釋放資源,但是經(jīng)過我測試,貌似只有 forget() 函數(shù)會釋放資源

查看是否資源被釋放也很簡單,登錄到對應(yīng)的 backend,我這里是 redis,使用 redis-cli 或者通過 docker 進(jìn)入 redis:

select 1keys*

查看相應(yīng)的 task id 是否還在列表就可以知道該資源是否被釋放

如果不想手動釋放資源,可以在配置里設(shè)置一個過期時間,那么結(jié)果就會在指定時間段后被釋放:

app.conf.update(result_expires=60)

這個我們可以在后面的配置里再詳細(xì)介紹。

以上就是本篇筆記全部內(nèi)容,下一篇筆記我們將介紹如何建立一個 celery 項(xiàng)目、配置的幾種方法及一些基本的配置。

如果想獲取更多后端相關(guān)文章,可掃碼關(guān)注閱讀:

標(biāo)簽:

推薦

財富更多》

動態(tài)更多》

熱點(diǎn)

成人伊人青草久久综合网_91在线视频免费观看_毛片免费视频网站_亚洲欧美日韩在线中文字幕

        亚洲欧美一区二区不卡| 欧美日韩成人一区| 精品理论电影在线观看| 一区二区三区四区在线免费观看 | 日韩视频在线永久播放| 亚洲品质自拍视频网站| 国产精品一卡二卡在线观看| 国产精品日韩精品欧美在线| 欧美日韩国产小视频在线观看| 中文字幕国产一区| 免费久久精品视频| 久久精品一区八戒影视| 欧美性受xxxx| 综合色中文字幕| 韩日精品视频一区| 亚洲欧洲精品一区二区三区| 欧美日韩黄视频| 亚洲免费观看高清完整版在线观看熊| 国内精品写真在线观看| 亚洲人成在线观看一区二区| 日韩一区二区视频| 亚洲v中文字幕| 94-欧美-setu| 在线观看免费亚洲| 综合久久国产九一剧情麻豆| 国产成人精品网址| 亚洲v日本v欧美v久久精品| 久久色在线视频| 美女mm1313爽爽久久久蜜臀| 国产精品久久久久久久第一福利 | 日韩欧美不卡在线观看视频| 亚洲gay无套男同| 国产日韩精品一区二区三区在线| 欧美午夜精品久久久久久超碰 | 国产精品精品国产色婷婷| 国产精品一区在线| 亚洲午夜久久久久久久久电影网 | 国产亚洲欧美日韩在线一区| 欧美日韩一区二区在线视频| 一区二区三区免费观看| 99国产精品国产精品毛片| 欧美视频中文字幕| 亚洲福利一二三区| 国产欧美一区二区精品性色 | 欧美一二三区精品| 日本不卡一区二区| 亚洲人成小说网站色在线| 欧美精品一区二区三区在线播放| 精品一区二区三区影院在线午夜| 亚洲已满18点击进入久久| 欧美国产综合色视频| 成人一区二区三区视频| 欧美亚洲一区二区在线| 亚洲成a人片在线不卡一二三区| 亚洲国产精品99久久久久久久久| 日韩欧美色电影| 韩国三级中文字幕hd久久精品| 亚洲自拍与偷拍| 亚洲欧美影音先锋| 久久精品人人爽人人爽| 欧美mv和日韩mv的网站| 国产一区二区成人久久免费影院| 色诱视频网站一区| 亚洲国产一区二区a毛片| 中文字幕精品三区| 久久影院电视剧免费观看| 国产高清亚洲一区| 欧美日韩高清一区二区不卡 | 日本道精品一区二区三区| 亚洲动漫第一页| 亚洲欧美在线高清| 中文字幕一区在线观看视频| 久久久久久久久久久久久久久99| 精品欧美乱码久久久久久| 国产不卡视频一区| 欧美日韩高清在线播放| 久久99久久99小草精品免视看| 亚洲成人激情av| 亚洲国产视频a| 一区二区三区免费观看| 亚洲天堂精品视频| 国产欧美视频在线观看| 中日韩av电影| 久久久久久久久久看片| 国产日韩成人精品| 久久久天堂av| 久久久高清一区二区三区| 99精品桃花视频在线观看| 精品日韩一区二区三区免费视频| 成人免费视频播放| 日韩欧美国产1| 不卡av电影在线播放| 日韩片之四级片| 不卡视频一二三| 欧美v国产在线一区二区三区| 成人黄色片在线观看| 欧美成人女星排名| 99国产麻豆精品| 久久久国际精品| 久久久久国产一区二区三区四区 | 国产99久久久国产精品免费看| 制服丝袜成人动漫| 成人综合在线视频| 精品免费一区二区三区| 91小宝寻花一区二区三区| 久久久久九九视频| 国产日韩欧美综合在线| 国产精品久久久久一区二区三区共| 国产精品美女久久久久久| 亚洲欧美aⅴ...| 亚洲高清不卡在线观看| 强制捆绑调教一区二区| 欧美日韩黄色影视| 成人精品一区二区三区四区| 久久精品亚洲麻豆av一区二区| 日本一区二区免费在线| 亚洲欧美成人一区二区三区| 亚洲福利一二三区| 日产精品久久久久久久性色| 欧美日韩亚洲丝袜制服| 成人高清av在线| 中文字幕不卡三区| 中文字幕制服丝袜一区二区三区| 一个色妞综合视频在线观看| 午夜电影一区二区三区| 激情综合网激情| 欧美精品一区二区三区在线 | 国产目拍亚洲精品99久久精品| 亚洲免费观看高清完整| 午夜精品久久久久久久| 国产激情视频一区二区三区欧美| 亚洲精品一区二区三区精华液 | 99精品在线免费| 亚洲视频香蕉人妖| 亚洲高清久久久| 国产高清一区日本| 国产农村妇女精品| 亚洲一区二区三区四区不卡| 久久精品国产久精国产| 日韩精品专区在线影院观看| 国产日产亚洲精品系列| 亚洲国产成人va在线观看天堂| 在线精品视频一区二区三四| 国产精品99久久久久久久vr| 国产亚洲欧美一级| 亚洲欧美在线视频| 久久国产精品99精品国产| 久久亚洲综合色| 亚洲免费在线观看| 久久精品国产99久久6| 久久在线免费观看| 一区二区三区在线观看视频| 韩国视频一区二区| 久久久99精品久久| 亚洲一区二区三区美女| 国产乱码一区二区三区| 国产精品日韩成人| 亚洲成在线观看| www.99精品| 亚洲图片欧美色图| 91精品国产综合久久精品| 日本一区免费视频| 男女性色大片免费观看一区二区| 亚洲精品在线观看网站| 亚洲一区二区三区中文字幕 | 亚洲精品国产视频| 欧美精品黑人性xxxx| 国产精品天美传媒| 精品一区二区日韩| 国产精品网站一区| 在线视频综合导航| 久久久www成人免费无遮挡大片| 日韩在线一区二区| 久久精品在线免费观看| 色综合久久综合| 久久久久国产精品麻豆| 美腿丝袜亚洲一区| 国产精品久久久久天堂| 欧美日韩中文另类| 国产精品久久久久久久久快鸭 | 亚洲v中文字幕| 2020日本不卡一区二区视频| 亚洲一区在线观看免费| 99精品视频一区二区| 日日夜夜一区二区| 欧美激情一二三区| 欧美色中文字幕| 日韩一区日韩二区| 成人免费毛片app| 五月婷婷综合在线| 国产丝袜美腿一区二区三区| 在线观看不卡一区| 国产精品乱码一区二区三区软件| 国产一区二区三区免费播放 | 国产欧美一区二区在线观看| 欧美影院午夜播放| 综合激情成人伊人| 成人免费观看男女羞羞视频| 日日摸夜夜添夜夜添精品视频| 国产日韩欧美a|