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

您的位置:首頁技術(shù)文章
文章詳情頁

Django celery實現(xiàn)異步任務操作,并在后臺運行(守護進程)

瀏覽:7日期:2024-09-11 16:38:43

沒廢話,直接上代碼。

環(huán)境說明:

python3.6

django2.0.5

我們使用redis的作為celery任務隊列,有一個合成包可以直接安裝兩者一起使用需要的安裝包

直接在終端鍵入

pip install celery-with-redis

就可以安裝需要的依賴包了

構(gòu)建項目過程略過,直接開始進行celery配置

一、celery配置。

我們的項目名稱為myproject,首先setting配置,添加

# celery settings# celery中間人 redis://redis服務所在的ip地址:端口/數(shù)據(jù)庫號BROKER_URL = ’redis://localhost:6379/3’# celery結(jié)果返回,可用于跟蹤結(jié)果CELERY_RESULT_BACKEND = ’redis://localhost:6379/3’ # celery內(nèi)容等消息的格式設置CELERY_ACCEPT_CONTENT = [’application/json’, ]CELERY_TASK_SERIALIZER = ’json’CELERY_RESULT_SERIALIZER = ’json’ # celery時區(qū)設置,使用settings中TIME_ZONE同樣的時區(qū)CELERY_TIMEZONE = TIME_ZONE

然后在PATH/myproject/myproject/即setting的同級目錄下創(chuàng)建celery.py,初始化celery。

from __future__ import absolute_import, unicode_literals from celery import Celeryfrom django.conf import settingsimport os # 獲取當前文件夾名,即為該Django的項目名project_name = os.path.split(os.path.abspath(’.’))[-1]project_settings = ’%s.settings’ % project_name # 設置環(huán)境變量os.environ.setdefault(’DJANGO_SETTINGS_MODULE’, project_settings) # 實例化Celeryapp = Celery(project_name) # 使用django的settings文件配置celeryapp.config_from_object(’django.conf:settings’) # Celery加載所有注冊的應用app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)

這里第一行輸入不能換位置,只能在首行,否則會報錯。

這里的實例化celery的app我們在別處要導入,為了方便導入,我們把它放到__init__.py里,所以在/myproject/myproject/__init__.py我們加入

from __future__ import absolute_import, unicode_literals # 引入celery實例對象from .celery import app as celery_app

這樣同時也能告知django celery.py文件的存在。

二、用celery裝飾我們的需要進行的異步函數(shù)。

我們在項目根目錄下創(chuàng)建celery_tasks模塊,即在PATH/myproject/下創(chuàng)建該模塊,然后在該模塊下創(chuàng)建tasks.py,把我們的耗時程序?qū)戇M去。

from myproject import celery_appimport time @celery_app.taskdef time_consuming_fun(): for i in range(5): time.sleep(1) print(i) return ’ok’

直接用我們的celery_app下的task方法裝飾需要進行異步處理的函數(shù)即可。

三、調(diào)用異步函數(shù)。

在view中調(diào)用,這里用的是Django的類視圖。

from celery_tasks.tasks import time_consuming_funfrom django.views import Viewfrom django.http import JsonResponse # Create your views here. class MyView(View): def get(self,request): #異步調(diào)用 time_consuming_fun.delay() #直接調(diào)用 #time_consuming_fun() return JsonResponse({’msg’:’ok’,’code’:200})

配置好url即可。

四、啟動celery。

在項目根目錄下,即managy同級文件目錄下,輸入命令:

celery -A myproject worker -l info

此時celery在終端窗口運行,關(guān)閉終端celery就會停止。

輸入命令

celery multi start w1 -A myproject -l info --logfile = celerylog.log --pidfile = celerypid.pid

此時celery為守護進程,日志記錄在celerylog.log里。

日志文件可以指定路徑PATH/celerylog.log,此時會在指定路徑下創(chuàng)建日志文件。進程號文件類似。

停止或重啟將開始換為stop或restart即可,所以需記錄w1,即需記錄woker的名稱來方便重啟和停止。

補充:Django項目后臺不掛斷運行

方法一:

1、進入項目目錄下,運行下面程序:

nohup python manage.py runserver 0.0.0.0:5008 &

nohup(no hang up)用途:不掛斷的運行命令

&用途:在后臺運行

nohup /root/start.sh &

在shell中回車后提示:

[~]$ appending output to nohup.out

原程序的的標準輸出被自動改向到當前目錄下的nohup.out文件,起到了log的作用。

注意:在nohup執(zhí)行成功后直接點擊關(guān)閉程序按鈕關(guān)閉終端,會斷掉該命令對應的session,導致nohup對應的進程被通知一起shutdown。所以在使用nohup命令后臺運行命令之后,需要使用exit正常退出當前賬戶,這樣才能保證命令一直在后臺運行。

方法二:這個比較高級,使用screen

1、安裝screen

yum install -y screen

2、新建一個screen

screen -S xiedi

這樣會新開一個窗口,然后執(zhí)行命令即可

python manage.py runserver 0.0.0.0:9000

3、重開一個窗口,列出所有screen進程,如下

[root@docker ~]# screen -lsThere are screens on: 3029.xiedi (Attached)

4、如果想鏈接上這個會話,執(zhí)行命令即可

screen -r 3029

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Django
主站蜘蛛池模板: 久久一区二区三区免费 | 亚州春色 | 亚洲成人在线免费 | 国产一级特黄视频 | 日韩中文视频 | 成人做爰www免费看 午夜精品久久久久久久久久久久 | 久久久www | 粉嫩av在线 | 久热精品在线观看视频 | 天天av网 | 一起操网站 | 欧美一区二区三区大片 | 亚洲成人一区二区 | 福利视频网站 | 日本a视频 | 国产高清免费 | 91在线精品一区二区 | 91国内精品久久 | 久久久激情视频 | 国产一区二区三区四 | 9191在线播放| 成人在线视频免费看 | 成人免费毛片在线观看 | 欧美在线观看一区 | 亚洲码欧美码一区二区三区 | 91精品久久久久久久99 | 日本成人午夜影院 | 国产精品久久久久久久久久免费看 | 操操操操操 | 91精品国产综合久久精品 | 欧美aa在线 | 免费一区二区 | 中文字幕成人网 | 午夜视频在线免费观看 | 九九热这里只有精品在线观看 | 免费骚视频 | 中文字幕一区二区三区四区五区 | 久草在线视频中文 | 精品久久久久香蕉网 | 成人高清在线 | 国产真实精品久久二三区 |