Django 为什么是芹菜干草堆?
对于django项目,我喜欢运行由芹菜工人更新的索引,以避免在解析页面时出错。我注意到芹菜干草堆能够做到这一点,但我想知道为什么它这么复杂。一个简单得多的解决方案是简单地从post_save信号应用异步任务,然后从那里调用信号处理器,这样就不用从信号处理器内部而是在之前应用异步部分 我想我错过了什么Django 为什么是芹菜干草堆?,django,django-haystack,django-celery,Django,Django Haystack,Django Celery,对于django项目,我喜欢运行由芹菜工人更新的索引,以避免在解析页面时出错。我注意到芹菜干草堆能够做到这一点,但我想知道为什么它这么复杂。一个简单得多的解决方案是简单地从post_save信号应用异步任务,然后从那里调用信号处理器,这样就不用从信号处理器内部而是在之前应用异步部分 我想我错过了什么 我知道在删除信号的情况下,实例可能不再存在…所以芹菜只是任务分发者,对吗?索引是需要完成的工作。搜索是最终结果。当您的资源有限时,任务将排队,并计划在工人可用的情况下运行。你可以很好地采用你的方法,
我知道在删除信号的情况下,实例可能不再存在…所以芹菜只是任务分发者,对吗?索引是需要完成的工作。搜索是最终结果。当您的资源有限时,任务将排队,并计划在工人可用的情况下运行。你可以很好地采用你的方法,但芹菜可以通过将任务分配给不同的工人来优化,这些工人可能在其他机器上工作。我有点忘记了细节。。。。(对不起)。但要说明的是:我最终没有使用芹菜干草堆,而是使用django信号(不仅仅是post_save,而是我创建了更具体的自定义信号)来触发异步芹菜任务(因此委托给其他队列/节点),并使用信号处理器运行索引更新。我还扩展了信号处理器,以支持更新和删除单个对象和iterable对象。
保罗思考后,你有什么见解吗?你最后用了什么?