【发布时间】:2017-08-21 04:22:59
【问题描述】:
我想确保一个任务——尤其是在单个实体上运行的任务——最多被添加到推送队列中,直到之前添加的任务完成为止。然后我应该能够再次为同一个实体添加相同的任务。
一个简单的例子是更新实体 A 的任务。我希望能够:
- 添加任务 X 以将实体 A 更新到推送队列。
- 当任务 X 在实体 A 的队列中时,为实体 A 添加任务 X 的所有其他尝试都应该失败。
- 完成后,我应该可以再次为实体 A 添加任务 X。
简单的解决方案似乎是使用包含任务 X 的名称和实体 A 的唯一 ID 的任务名称。
但是,我认为这种方法不满足条件 3:任务名称在无法控制的时期内被“墓碑化”并且在此之前无法重复使用。
来自docs:
分配您自己的任务名称的一个优点是命名任务是 去重,这意味着您可以使用任务名称来保证* 任务只添加一次。重复数据删除持续 9 天后 任务已完成或删除。
这是否意味着任务名称在 9 天内不能重复使用?
【问题讨论】:
-
为什么需要#2?
-
这样我就不会因为更新该实体而发生不必要的争执。
-
那么您如何处理无法将更新任务排入队列的实体更改?
-
@DanCornilescu 下次运行任务以更新该实体时,它将捕获干预更改(只需计算所有满足特定条件的实体,然后将计数存储在属性中)。
标签: java google-app-engine task-queue