0

0

在 Django 中使用 SQLite 作为 Celery 代理

WBOY

WBOY

发布时间:2024-07-25 19:01:02

|

623人浏览过

|

来源于dev.to

转载

在 django 中使用 sqlite 作为 celery 代理

redis 和 rabbitmq 可能是使用 celery 时的首选代理,但当您在本地开发时,它们可能会让人感觉大材小用。 celery 5.4 的文档提到您可以使用 sqlite 作为本地开发的实验代理。然而,当您导航到 celery 的后端和代理页面时,唯一提到的 sql 是针对 sqlalchemy 后端。值得庆幸的是,该页面指出,“本节并未全面介绍后端和代理。”

这篇文章将向您展示如何在 django 项目中为 celery 实现 sqlite 代理(或任何 sql!)。这篇文章不会教你使用 celery:查看 celery 官方文档。

在我们开始之前

出于本文的目的,我们假设您已经有一个现有的 django 项目,并且使用 celery 官方“django 的第一步”指南中的步骤安装了 celery。 celery 后端不是必需的,但您可能需要按照指南的步骤安装和配置 django-celery-results。如果您不清楚后端经纪人之间的区别,请查看我的文章“了解 celery 中的任务、经纪人、工作人员和后端”。

除非另有明确说明,所有源文档链接均适用于发布时(2024 年 7 月)当前版本的 django、celery 和 sqlalchemy。如果你在遥远的将来读到这篇文章,事情可能已经改变了。

设置 sql 代理

虽然 celery 管理任务和队列,但它委托给另一个名为 kombu 的库来与代理交换消息。 rabbitmq 和 redis 是 kombu 功能最齐全的传输(代理),但它还具有适用于 amazon sqs、zookeeper 和 mongodb 的虚拟传输。

隐藏在 kombu 文档的最角落里的是一个支持 postgresql、mysql 和 sqlite 的 sqlalchemy 传输模型。曾几何时,sqlalchemy 代理甚至在 celery 的网站上有记录,但此后它已从库的新版本的文档中删除。尽管如此,它仍然足以满足当地的发展。

要在 django 应用程序中使用后续数据库作为 celery 代理,请首先安装 sqlalchemy:

pip install sqlalchemy

在 django 项目的 settings.py 文件中,您可以使用 celery_broker_url 设置来设置代理的后端:

# base_dir is the directory of your project's main directory.

celery_broker_url = f"sqlalchemy+sqlite:////{base_dir}/broker.sqlite3"

sqlalchemy 经纪人 url 由 3 部分组成:

ShoopD 网上商店系统
ShoopD 网上商店系统

用 php + mysql 驱动的在线商城系统,我们的目标为中国的中小企业及个人提供最简洁,最安全,最高效的在线商城解决方案,使用了自建的会员积分折扣功能,不同的会员组有不同的折扣,让您的商店吸引更多的后续客户。 系统自动加分处理功能,自动处理会员等级,免去人工处理的工作量,让您的商店运作起来更方便省事 采用了自建的直接模板技术,免去了模板解析时间,提高了代码利用效率 独立开发的购物车系统,使用最

下载
  1. 字符串 sqlalchemy 或 sqla (它们可以互换)
  2. a+号
  3. 一个 sqlalchemy 连接字符串

mac/unix 和 windows 上的 sqlite 连接字符串是不同的:

# macos/unix
celery_broker_url = "sqla+sqlite:////your/project/path/broker.sqlite3"

# windows
celery_broker_url = "sqla+sqlite:///c:your\\project\\path\\broker.sqlite3"

您还可以使用 postgres 作为 celery 代理,或者您也可以轻松使用 mysql 作为 celery 代理:

# mysql
celery_broker_url = "sqlalchemy+mysql://scott:tiger@localhost/foo"

# postgresql
celery_broker_url = "sqla+postgresql://scott:tiger@localhost/mydatabase"

# posgresql connecting using pg8000
celery_broker_url = "sqla+postgresql+pg8000://scott:tiger@localhost/mydatabase"

您可能需要安装其他库来连接 mysql 或 postgresql,您安装的库可能会影响 sqlalchemy 连接字符串。检查 sqlalchemy 数据库 url 文档以获取更多详细信息。

无论您选择哪个数据库,您都可能需要考虑将代理 url 存储在环境变量中,以便在不同环境中轻松更改:

CELERY_BROKER_URL = os.getenv("CELERY_BROKER_URL")

一句警告

sqlalchemy 传输可能被认为是实验性的,因此它不适合生产使用。可能会发生数据丢失,或者消息可能会被多次传送。考虑切换到 celery 的经纪商和后端页面上列出的更强大的经纪商。

也就是说,这对于本地开发,甚至小型副项目来说可能没问题。但如果将来无法使用 sqlalchemy 作为代理,我也不会感到震惊。

下一步

在本地运行 celery 后,您就可以开始开发队列驱动的应用程序了。然而,您可能会发现它缺乏自动重新加载是一个摩擦点。如果您想在 django 应用程序中设置自动 celery 重新加载,请阅读我的文章“使用自定义 django 命令自动重新加载 celery 工作线程。”

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

683

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

358

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

677

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

575

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

417

2024.04.29

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 804人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号