想象一下情况:
var txn = new DatabaseTransaction();
var entry = txn.Database.Load<Entry>(id);
entry.Token = "123";
txn.Database.Update(entry);
PublishRabbitMqMessage(new EntryUpdatedMessage { ID = entry.ID });
// A bit more of processing
txn.Commit();
现在,消费者EntryUpdatedMessage
可能会在事务提交之前txn
获得此消息,因此将无法看到更新。
现在,我知道 RabbitMQ 本身确实支持事务,但我们不能真正使用它们,因为我们IModel
为每个发布创建一个新的,并且在我们的场景(ASP.NET Web 应用程序)中拥有每线程模型真的很麻烦。
我想过在提交数据库事务时发布一个消息列表,但这是一个非常糟糕的解决方案。
处理这个的正确方法是什么?