我正在横向扩展应用程序,并且已经意识到读取模型更新(通过事件处理程序的外部投影)将需要在竞争消费者的基础上进行处理。
我最初假设我需要确保订购,但此要求取决于消息。在我想知道总数的购物车结账的情况下,无论订单如何,我都可以添加总数 - 获取消息,更新 SQL 数据库,然后确认消息。
我现在绞尽脑汁想出一个场景/消息,但我知道情况并非如此。一些额外的清晰度和示例将非常有用。
我需要帮助的问题是:
排序需要什么类型的消息很重要,以及如何按原样使用消息来解决这个问题?
当进程加入/离开时,我们如何知道要从哪个事件重新订阅我可以看到可能导致对刚刚被另一个进程处理的消息请求订阅的时间问题?
我看到有一种
Pinned
消费者策略可以使流与订阅者的最大努力亲和力,但这并不能保证。我可以解决这个问题,使特定的流单线程只按顺序处理那些消息 - 一个进程是否可以对不同的流进行多个订阅?