Django-Q设置Django调度和定时任务

场景说明:

Django项目需要实现每30秒刷新一次首页信息

1.安装库

复制代码
pip install django-q

2.添加app

复制代码
INSTALLED_APPS = [
       # ... 其他应用程序 ...
       'django_q',
   ]

3.配置

复制代码
Q_CLUSTER={ 
        'name':'project', 
        'workers':4, 
        'recycle':500, 
        'timeout':60, 
        'compress':True, 
        'cpu_affinity':1, 
        'save_limit':250, 
        'queue_limit':500, 
        'label':'DjangoQ', 
        'redis':{ 
            'host':'127.0.0.1', 
            'port':6379, 
            'db':0, 
        } 
    }

4.定义一个任务,例如打印一条消息(异步执行)

复制代码
# tasks.py
from django_q.tasks import async_task
def print_message():
    print("This is a message from Django - Q")
async_task(print_message)

5.定时任务示例

  • 这里需要注意几点:
    • func参数需要指定任务函数的完整路径,格式为app_name.module_name.task_function_name。你需要将your_app_name替换为你的 Django 应用的实际名称,q_tasks(如果你的任务函数定义在q_tasks.py文件中)替换为实际的模块名称。

    • schedule_type指定了时间单位的类型,这里使用Schedule.MINUTES表示以分钟为单位。然后通过minutes参数设置具体的时间间隔,0.5 分钟即 30 秒。

    • repeats参数设置为 - 1,表示这个任务会无限次地重复执行。如果你想让任务只执行一定的次数,可以设置一个正整数。

      from django_q.models import Schedule
      from django_q.tasks import async_task
      import time

      def my_task():
      print("This task is executed every 30 seconds.")
      # 这里可以添加实际要执行的任务逻辑,比如更新数据、发送通知等

      创建定时任务

      Schedule.objects.create(
      func='your_app_name.q_tasks.my_task', # 替换为你的应用名称和任务函数所在的模块路径
      schedule_type=Schedule.MINUTES,
      minutes=0.5, # 因为0.5分钟就是30秒
      repeats=-1 # -1表示无限重复执行任务
      )

6.启动Django-Q

  • 在你的 Django 项目的启动文件(如urls.py或者apps.py等)中启动 Django - Q 任务队列。例如,在urls.py中添加以下代码:

    import qcluster
    qcluster.start()

7.启动项目,启动后队列也开始执行

相关推荐
小杨同学49几秒前
C 语言实战:3 次机会密码验证系统(字符串处理 + 边界校验)
后端
山峰哥2 分钟前
3000字深度解析:SQL调优如何让数据库查询效率提升10倍
java·服务器·数据库·sql·性能优化·编辑器
小oo呆7 分钟前
【学习心得】Python的Pydantic(简介)
前端·javascript·python
岚天start7 分钟前
【日志监控方案】Python脚本获取关键字日志信息并推送钉钉告警
python·钉钉·日志监控
天天摸鱼的java工程师8 分钟前
工作中 Java 程序员如何集成 AI?Spring AI、LangChain4j、JBoltAI 实战对比
java·后端
tyatyatya9 分钟前
MySQL Group Replication(MGR)集群部署,实现自动故障切换
数据库·mysql
b***59439 分钟前
mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案
数据库·sql·mysql
木风小助理10 分钟前
MySQL中COUNT()、COUNT(1)与COUNT
数据库
叫我:松哥10 分钟前
基于 Flask 框架开发的在线学习平台,集成人工智能技术,提供分类练习、随机练习、智能推荐等多种学习模式
人工智能·后端·python·学习·信息可视化·flask·推荐算法