如何解决Rebus传奇的一致性
我正面临着一种奇怪的情况,即我的sagas 有时 只是停止调用后续步骤,而没有错误写入日志。因此,例如考虑以下(伪)代码:
public async Task Handle(Step1 step1)
{
//... do something
await _bus.Send(new Step2 { Id = step1.Id });
}
public async Task Handle(Step2 step2)
{
//... do something else
// go to next step
}
在这种情况下,step1
可以很好地处理,但是没有迹象表明Handle(Step2 step2)
曾经被使用仅存在于sql表中的revision
字段等于{ {1}},并且RabbitMq的主队列或错误队列中没有消息。是否至少适用一次交货保证?关于如何实现或我可以添加哪些调试信息的任何建议?
我在此配置中使用MysqL持久性和RabbitMq传输:
1
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。