NServiceBus警告“无法找到消息类型的处理程序”

时间:2012-09-05 14:14:20

标签: c# nservicebus

我是NServiceBus的新手,我正在尝试开发一个发布者和单独的订阅者(我正在使用v3.2.0.0),到目前为止,这种工作正常 - 发布者和订阅者都在NServiceBus主机中运行。我的消息全部发布正常但是间歇性地它们不被订阅者接收,发布者显示以下错误:

2012-09-05 14:27:37,491 [Worker.6] WARN  NServiceBus.Unicast.UnicastBus [(null)]  <(null)> - No handlers could be found for message type: MyNamespace.MyMessage

但是,对于所有消息都没有出现此警告,因此,如果我在消息之后继续发布消息,我可能会看到其中一半显示消息,因此未被订阅者接收,尽管所有消息都出现在MSMQ队列中。

我承认我很难掌握这个,所以到目前为止我的一些代码可能完全是垃圾!

我按如下方式向NSB发布消息,消息输入是我定义的几种不同类型之一:

private void Publish<T>(T message)
{
    var myBus = Configure.Instance.Builder.Build<IBus>();
    myBus.Publish(message);
}

发布者的EndpointConfig如下:

[EndpointName("MyQueue")]
public class EndpointConfig : IConfigureThisEndpoint, AsA_Publisher, IWantCustomInitialization
{
    /// <summary>
    /// Initialisation for NServiceBus.
    /// </summary>
    public void Init()
    {
        Configure.With()
            .DefaultBuilder()
            .MsmqSubscriptionStorage()
            .DisableTimeoutManager()
            .DefiningEventsAs(t => t.Namespace != null && t.Namespace.StartsWith("MyNamespace"));
    }
}

在订阅方,我有以下EndpointConfig:

[EndpointName("MyQueue")]
public class EndPointConfig : IConfigureThisEndpoint, AsA_Server, IWantCustomInitialization
{
    public void Init()
    {
        Configure.With()
            .DefiningEventsAs(t => t.Namespace != null && t.Namespace.StartsWith("MyNamespace"));
    }
}

使用EventMessageHandler,如下所示:

public class EventMessageHandler : IEvent, IHandleMessages<IMyMessage>
{
    public void Handle(IMyMessage message)
    {
        Console.WriteLine(string.Format("Subscriber 1 received EventMessage with Id {0}.", message.Id));
    }
}

订阅者的app.config是:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <section name="UnicastBusConfig" type="NServiceBus.Config.UnicastBusConfig, NServiceBus.Core" />
    <section name="MessageForwardingInCaseOfFaultConfig" type="NServiceBus.Config.MessageForwardingInCaseOfFaultConfig, NServiceBus.Core" />
  </configSections>

  <MessageForwardingInCaseOfFaultConfig ErrorQueue="error"/>

  <UnicastBusConfig>
    <MessageEndpointMappings>
      <add Messages="MyNamespace" Endpoint="MyQueue" />
    </MessageEndpointMappings>
  </UnicastBusConfig>
</configuration>

1 个答案:

答案 0 :(得分:9)

您的发布商和订阅者看起来都使用相同的端点名称。 NServiceBus使用端点名称生成队列名称,这意味着两个进程都使用相同的队列。

因此,您的发布商实际上是在发布消息,但是发布商和订阅者正在争论谁来处理它们。

当订阅者获胜时,您会看到您的预期行为。

当发布者获胜时,该消息没有处理程序,因此NServiceBus会显示警告。这并不总是一个问题;在某些情况下,您希望接收并简单地忽略消息,但此警告允许您至少知道它正在发生,并且在您的情况下,它表示消息未被预期的应用程序处理。

因此,要修复它,只需更改端点名称即可。 MySubscriber和MyPublisher,或类似的东西。

您甚至不需要使用该属性,您只需命名实现IConfigureThisEndpoint的类,NServiceBus将根据该名称构建端点名称。您甚至可以使用MyProject_MyPublisher : IConfigureThisEndpoint和NServiceBus等下划线将下划线转换为点,这样您就可以获得“MyProject.MyPublisher”的输入队列,当您运行许多端点时,这对于命名空间非常好。 / p>