Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Django 为什么是芹菜干草堆?_Django_Django Haystack_Django Celery - Fatal编程技术网

Django 为什么是芹菜干草堆?

Django 为什么是芹菜干草堆?,django,django-haystack,django-celery,Django,Django Haystack,Django Celery,对于django项目,我喜欢运行由芹菜工人更新的索引,以避免在解析页面时出错。我注意到芹菜干草堆能够做到这一点,但我想知道为什么它这么复杂。一个简单得多的解决方案是简单地从post_save信号应用异步任务,然后从那里调用信号处理器,这样就不用从信号处理器内部而是在之前应用异步部分 我想我错过了什么 我知道在删除信号的情况下,实例可能不再存在…所以芹菜只是任务分发者,对吗?索引是需要完成的工作。搜索是最终结果。当您的资源有限时,任务将排队,并计划在工人可用的情况下运行。你可以很好地采用你的方法,

对于django项目,我喜欢运行由芹菜工人更新的索引,以避免在解析页面时出错。我注意到芹菜干草堆能够做到这一点,但我想知道为什么它这么复杂。一个简单得多的解决方案是简单地从post_save信号应用异步任务,然后从那里调用信号处理器,这样就不用从信号处理器内部而是在之前应用异步部分

我想我错过了什么


我知道在删除信号的情况下,实例可能不再存在…

所以芹菜只是任务分发者,对吗?索引是需要完成的工作。搜索是最终结果。当您的资源有限时,任务将排队,并计划在工人可用的情况下运行。你可以很好地采用你的方法,但芹菜可以通过将任务分配给不同的工人来优化,这些工人可能在其他机器上工作。

我有点忘记了细节。。。。(对不起)。但要说明的是:我最终没有使用芹菜干草堆,而是使用django信号(不仅仅是post_save,而是我创建了更具体的自定义信号)来触发异步芹菜任务(因此委托给其他队列/节点),并使用信号处理器运行索引更新。我还扩展了信号处理器,以支持更新和删除单个对象和iterable对象。
保罗

思考后,你有什么见解吗?你最后用了什么?