Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务

目录

一、实验

1.Django使用Celery完成异步和定时任务

二、实验

1. 如何查看Django版本


一、实验

1.Django使用Celery完成异步和定时任务

(1)安装Django

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第1张图片

(2)新建Django项目

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第2张图片

(3)初始框架

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第3张图片

(4)urls.py引用视图views

from django.contrib import admin
from django.urls import path
from app01 import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('test/',views.test)
]

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第4张图片

(5)编写view

from django.shortcuts import render,HttpResponse

# Create your views here.
def test(request):

    return HttpResponse("OK")

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第5张图片

(6)点击运行

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第6张图片

(7)查看运行结果,点击链接

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第7张图片

(8)显示OK

http://127.0.0.1:8000/test/

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第8张图片

(9)新建消费者目录mycelery

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第9张图片

(10)tasks.py文件定义异步或定时任务

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第10张图片

(11)编写配置文件config.py

#消息中间件
broker_url = 'redis://127.0.0.1:6379/15'
#异步存储地方
result_backend = 'redis://127.0.0.1:6379/14'

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第11张图片

(12)main.py将配置文件解耦

# -*- coding: utf-8 -*-
# 主程序
import os
import celery as celery
from celery import Celery
import eventlet
# 创建celery实例对象
app = Celery("djcelery")
# 把celery和django进行组合,识别和加载django的配置文件
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'celeryPros.settings.dev')
# 通过app对象加载配置
app.config_from_object("mycelery.config")
# 加载任务
# 参数必须必须是一个列表,里面的每一个任务都是任务的路径名称
# app.autodiscover_tasks(["任务1","任务2"])
app.autodiscover_tasks(["mycelery.sms",])

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第12张图片

(13)tasks文件

# -*- coding: utf-8 -*-
# celery的任务必须写在tasks.py的文件中,别的文件名称不识别!!!
from mycelery.main import app
import time
import logging
log = logging.getLogger("django")
@app.task  # name表示设置任务的名称,如果不填写,则默认使用函数名做为任务名
def send_sms(mobile):
    """发送短信"""
    print("向手机号%s发送短信成功!"%mobile)
    time.sleep(5)
    return "send_sms OK"
@app.task  # name表示设置任务的名称,如果不填写,则默认使用函数名做为任务名
def send_sms2(mobile):
    print("向手机号%s发送短信成功2!"%mobile)
    time.sleep(5)
    return "send_sms2 OK"

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第13张图片

(14)view视图添加异步代码

from django.shortcuts import render,HttpResponse
# Create your views here.
from mycelery.sms.tasks import send_sms,send_sms2
def test(request):
    #异步任务
    # 1. 声明一个和celery一模一样的任务函数,但是我们可以导包来解决
    # send_sms.delay("139XXXXXXXX")
    # send_sms2.delay("135XXXXXXXX")
    # send_sms.delay() 如果调用的任务函数没有参数,则不需要填写任何内容

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第14张图片

(15)浏览器刷新或回车,进行观察

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第15张图片

(16)消费者一方配置完成

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第16张图片

(17) mycelery根目录

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第17张图片

(18)已启动消费

PS D:\soft\Djcelery> celery --app=mycelery.main worker -n node1 -l INFO -P eventlet

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第18张图片

(19)查看异步消息

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第19张图片

(20)注释异步任务代码

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第20张图片

(21)添加定时任务代码

    #定时任务
    from datetime import datetime,timedelta
    ctime = datetime.now()
    # 默认用utc时间
    utc_ctime = datetime.utcfromtimestamp(ctime.timestamp())
    time_delay = timedelta(seconds=10)
    task_time = utc_ctime + time_delay
    result = send_sms.apply_async(["136XXXXXXXX", ], eta=task_time)
    print(result.id)

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第21张图片

(22)浏览器再次刷新或回车,进行观察

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第22张图片

(23)查看定时消息

(24)查看RUN结果

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第23张图片

(25)完整项目架构

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第24张图片

(26)查看Redis可视化界面

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第25张图片

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第26张图片

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第27张图片

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第28张图片

二、实验

1. 如何查看Django版本

(1)方式一

indows系统下,在cmd命令窗口中输入python进入Python解释器
Linux系统下, 直接使用终端调用Python解释器

接下来输入:
>>> import django
>>> print django.VERSION # Python2的格式
>>> print(django.VERSION) # Python3的格式 

或者输入:
>>> django.get_version()  # 获取当前djiango版本号

(2)方式二

在IDE内 的terminal 内输入

python -m django --version

django-admin --version

这两个命令 一样可以查询到。

注意:通常在项目的目录下查询。这种方式适合项目已经建立,虚拟Python环境也已经配置好。Django不是全局安装的时候。

(3)方式三

Windows系统下,在cmd命令窗口中输入python进入Python解释器

Linux系统下,直接使用终端调用Python解释器

直接输入:
python -m django --version

django-admin --version

注意:这里django是全局安装。

(4)方法四

在项目目录下的lib文件夹内的site-packpage文件夹内直接可以看到Django版本。

Python开发运维:Django 4.2.7 使用Celery 5.3.5 完成异步和定时任务_第29张图片

你可能感兴趣的:(python开发运维,django,python,后端,运维)