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.启动项目,启动后队列也开始执行

相关推荐
Database_Cool_2 小时前
云原生多租户隔离 + 近实时分析怎么选型?阿里云 AnalyticDB MySQL 资源隔离方案
数据库·mysql·阿里云
集成显卡8 小时前
Rust实战七 |基于带 colored 颜色文字控制台的批量文件删除工具
开发语言·后端·rust
小马爱打代码8 小时前
Redis 集群方案详解:主从复制、哨兵、脑裂、分片集群和哈希槽
数据库·redis·哈希算法
jeffer_liu9 小时前
Spring AI 生产级实战:工具调用
java·人工智能·后端·spring·ai编程
lifloveyou9 小时前
table接口结构
python
海南java第二人9 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat9 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
Cosolar9 小时前
AutoGen 精通教程:从零到企业级多 Agent 系统架构师
人工智能·后端·面试