c# - 解析来自总线的命令

标签 c# autofac bus easynetq

目前正在远离处理命令同步并将它们放在消息总线上以便稍后处理它们但是在尝试加载命令而不是键入每个命令时返回真实类型时遇到问题

这是我目前所拥有的并且似乎工作正常

命令调度器

  public class CommandDispatcher : ICommandDispatcher
{
    private readonly IBus _commandBus;

    public CommandDispatcher(IBus commandBus)
    {
        _commandBus = commandBus;
    }

    public void Dispatch<TCommand>(TCommand command) where TCommand : ICommand
    {
        var messageType = typeof(TCommand);

        _commandBus.Publish(messageType, command);
    }

订阅命令

  bus.Subscribe<CommandOne>("key", HandleCommand);
  bus.Subscribe<CommandTwo>("key", HandleCommand);

处理消息

   private void HandleCommand<TCommand>(TCommand command) where TCommand : ICommand
    {
        var handler = _container.Resolve<ICommandHandler<TCommand>>();

        handler.Handle(command);
    }

我基本上想按照约定解决我的消息,所以这是我想要的方向,所以我不必键入每个命令类型,但在取回类型时遇到问题

        var commandAssembly = Assembly.GetAssembly(typeof(ICommand));

        var commands = commandAssembly.GetTypes().Where(x => typeof(ICommand).IsAssignableFrom(x));

        foreach (var command in commands)
        {
            bus.Subscribe(command, "key", x =>
            {
                HandleCommand(x);

            });
        }

现在 x 只是一个我不能传递给 Handlecommand 方法的对象

我为我的容器使用 autofac,为我的总线使用 easynetq。

最佳答案

我认为这部分:

   private void HandleCommand<TCommand>(TCommand command) where TCommand : ICommand
    {
        var handler = _container.Resolve<ICommandHandler<TCommand>>();

        handler.Handle(command);
    }

如果您实现 IConsume<T>,所有这些都由 AutoSubscriber 为您完成而不是 ICommandHandler<T> , 他们似乎有相同的目的。

https://github.com/EasyNetQ/EasyNetQ/wiki/Auto-Subscriber

是否有任何特定原因需要单独的 ICommandHandler<T>界面?

另一个注意事项:在您的实现中,您在解析命令处理程序时没有创建单独的“作用域”,导致处理程序的每个实例(以及任何依赖项)永远存在于“根”作用域中。换句话说:内存泄漏 :)

如果你仍然想坚持你的实现,我认为最好做这样的事情:

   private void HandleCommand<TCommand>(TCommand command) where TCommand : ICommand
    {
        using(var scope = _container.BeginLifetimeScope("my-command-scope"))
        {
          var handler = scope.Resolve<ICommandHandler<TCommand>>();
          handler.Handle(command);
        }
    }

但是,如果您使用 AutoSubscriber,这就是 AutofacMessageDispatcher 将为您做的事情:

https://github.com/EasyNetQ/EasyNetQ/blob/master/Source/EasyNetQ.DI.Autofac/AutofacMessageDispatcher.cs

关于c# - 解析来自总线的命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39298876/

相关文章:

c# - Authorize 和 Request.IsAuthenticated 之间的区别

json - 具有 KeyFilter 属性的构造函数的 Autofac 配置

Azure服务总线: Best way to implement exponential retry policy for failed to process messages

c# - ID如何在asp : TextBox?中工作

c# - Firefox 中如何修复表格列空白?

autofac - 如何在自定义 TelemetryInitializer 中注入(inject)依赖项?

c# - NServiceBus IoC 序列化异常

cxf - "org.apache.cxf.jaxrs.bus.providers"不工作

c - GDBus 相当于 dbus_connection_setup_with_g_main()

c# - Kinect 应用程序的源逆向工程