我正在使用MassTransit并在我的应用程序中使用以下代码:
RequestMsg request = buildMeARequest();
SomeTypeOfResponse response = null;
_serviceBus.PublishRequest(request, c =>
{
c.Handle<SomeTypeOfResponse>(message => response = message);
c.SetTimeout(TimeSpan.FromSeconds(30));
});
return response;
在消费者方面,我有类似的东西:
public class RequestMsgConsumer : Consumes<T>.All
{
public RequestMsgConsumer(IServiceBus serviceBus)
{
_serviceBus = serviceBus;
}
public void Consume(RequestMsg request)
{
SomeTypeOfResponse response = doWorkToGetResponse(request);
_serviceBus.Context().Publish(response);
}
}
当一切顺利时,这很有效...但是如果doWorkToGetResponse(request)
抛出异常(或Consume()
方法的任何部分真的)原始请求者超时,则没有失败的迹象
我最初的想法是构建一个像Either<Exception, SomeTypeOfResponse>
这样的类,以便请求者总是期望这个Either<>
构造,但这将迫使我总是尝试/捕获每个消费方法 - 并且他们很多。
还有其他人更优雅地解决了这个问题吗?
答案 0 :(得分:2)
我相信您想要的是将c.HandleFault(fault => ...)
添加到PublishRequest
。
如果这不起作用,过去一周或两周就会在邮件列表上发布一些关于下一版本中某些修补程序的消息。我认为失败仅限于Sagas,但我可能是错的。