内容简介:有没有办法在Django中提交事务后运行一些代码?我需要发送一些消息给一个rabbitmq服务器进行离线处理,但是在Django事务被提交之前消息会传给消费者.我的消息是在模型的post_save信号中发送的.我正在寻找的是一种类似的机制,使用信号或其他东西,将在提交后执行代码(如果事务失败,则不执行任何操作).
有没有办法在Django中提交事务后运行一些代码?
我需要发送一些消息给一个rabbitmq服务器进行离线处理,但是在Django事务被提交之前消息会传给消费者.
我的消息是在模型的post_save信号中发送的.我正在寻找的是一种类似的机制,使用信号或其他东西,将在提交后执行代码(如果事务失败,则不执行任何操作).
我没有找到任何通用的Django方法.你有什么想法吗
更新2:django-transaction-hooks是 merged into Django core
,并在Django版本1.9中发布.
更新: django-transaction-hooks 解决了这个问题.
我不相信有一个干净的方法来做到这一点;至少我不能想到一个.您可以使用monkeypatch django.db.transaction.commit发送自定义信号;不漂亮,但我认为它会工作.
在 django-developers mailing list 也可能提出这个用例.开发人员通常厌恶添加新的信号,但您可能会在这里有一个很好的例子(核心开发人员的反驳可能包括一个有用的建议如何解决您的情况).如果等到1.1出来之后,你就更有可能得到回应.
http://stackoverflow.com/questions/950214/run-code-after-transaction-commit-in-django
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Spark 系列(五)—— Spark 运行模式与作业提交
- spark源码解析-从提交任务到jar的加载运行(基于2.1.0版本)
- Git提交错误时如何删除Git提交记录
- 分布式系统 - 两段式提交(2PC)和三段式提交(3PC)
- 减半前,比特币开发者代码提交数创历史新高:4月累计提交510次
- 提交任务到Spark
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。