如何解决使用约定非干扰模式找不到NServiceBus通用消息处理程序
我正在将dotnetcore2.1应用程序与aspnetcore 2.1.1一起使用。
另外,我正在按照文档中的建议使用Community.NServiceBus.WebHost
托管该版本。
我试图拥有一个干净的体系结构,使其不直接依赖于NServiceBus,因此我在命令中使用了适配器和非干扰模式。我收到以下异常,并立即尝试重试。
system.invalidOperationException: No handlers Could be found for message type: WebApi.Models.Commands.ProcessBlob
public static IServiceCollection AddNServiceBus(this IServiceCollection services,IConfiguration configuration)
{
var endpointName = configuration.GetValue<string>("NServiceBus:EndpointName");
var connectionString = configuration.GetValue<string>("NServiceBus:ConnectionString");
var endpointConfiguration = new EndpointConfiguration(endpointName);
endpointConfiguration.SendFailedMessagesTo("error");
endpointConfiguration.EnableInstallers();
var conventions = endpointConfiguration.Conventions();
conventions.DefiningMessagesAs(type => type.Namespace != null && type.Namespace.Contains(".Commands"));
//var transport = endpointConfiguration.UseTransport<AzureServiceBusTransport>();
//transport.ConnectionString(connectionString);
endpointConfiguration.UseTransport<LearningTransport>();
services.AddNServiceBus(endpointConfiguration);
services.AddTransient<ICommandBus,CommandBusAdapter>();
services.AddTransient<ICommandHandler<ProcessBlob>,ProcessBlobHandler>();
return services;
}
然后在Startup.cs
public void ConfigureServices(IServiceCollection services)
{
services
.AddNServiceBus(Configuration)
.AddMvc()
.SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
}
我有以下用于发送命令的适配器
public class CommandBusAdapter
: ICommandBus
{
private readonly IMessageSession _messageSession;
public CommandBusAdapter(IMessageSession messageSession)
{
_messageSession = messageSession;
}
public Task Send<TCommand>(TCommand command)
where TCommand : class
{
return _messageSession.SendLocal(command);
}
}
这是我的通用消息处理程序适配器,用于处理ANY命令并使用服务定位器确定要委派的特定命令处理程序。
public class CommandHandlerAdapter<TCommand>
: IHandleMessages<TCommand>
where TCommand : class
{
private readonly IServiceProvider _serviceProvider;
public CommandHandlerAdapter(IServiceProvider serviceProvider)
{
_serviceProvider = serviceProvider;
}
public Task Handle(TCommand message,IMessageHandlerContext context)
{
var commandHandlerType = typeof(ICommandHandler<TCommand>);
var commandHandler = (ICommandHandler<TCommand>)_serviceProvider.GetService(commandHandlerType);
return commandHandler.Handle(message);
}
}
如您所见,命令处理程序适配器未注册(我希望NServiceBus能够检测到它并自动注册它,即使它是通用的)。
我使用约定,命令消息是包含.Commands
我是否正在尝试一些不可能的事情,或者有什么变通办法可以让我继续使用这种通用的命令处理程序适配器方法?
更新1 :换句话说,以下处理程序可以正常运行而无需任何其他注册。
public class CommandHandlerAdapter
: IHandleMessages<ProcessBlob>
{
private readonly ICommandHandler<ProcessBlob> _processBlobHandler;
public CommandHandlerAdapter(ICommandHandler<ProcessBlob> processBlobHandler)
{
_processBlobHandler = processBlobHandler;
}
public Task Handle(ProcessBlob processBlob,IMessageHandlerContext context)
{
return _processBlobHandler.Handle(processBlob);
}
}
但是我想要一种通用的命令处理程序适配器,因为它对每个命令都执行相同的操作(获取特定命令处理程序的实例并委托它来处理消息)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。