【发布时间】:2015-04-13 13:30:44
【问题描述】:
我有两个端点,一个是 NSB 2.5 并发布消息,一个是 NSB 4.7.5。我想订阅 NSB2 在我的 NSB4 端点中发布的事件,但是当我将订阅添加到 NSB4 端点时,我在 NSB2 端点中收到以下错误:
System.Xml.XmlException: Root element is missing.
at System.Xml.XmlTextReaderImpl.Throw(Exception e)
at System.Xml.XmlTextReaderImpl.ThrowWithoutLineInfo(String res)
at System.Xml.XmlTextReaderImpl.ParseDocumentContent()
at System.Xml.XmlTextReaderImpl.Read()
at System.Xml.XmlLoader.Load(XmlDocument doc, XmlReader reader, Boolean preserveWhitespace)
at System.Xml.XmlDocument.Load(XmlReader reader)
at NServiceBus.Serializers.XML.MessageSerializer.Deserialize(Stream stream) in c:\dev\v3\NServiceBus\src\impl\Seri
at NServiceBus.Unicast.Transport.Msmq.MsmqTransport.Extract(Message message) in c:\dev\v3\NServiceBus\src\impl\uni
at NServiceBus.Unicast.Transport.Msmq.MsmqTransport.ReceiveFromQueue() in c:\dev\v3\NServiceBus\src\impl\unicast\N
我的 NSB2 错误队列中有以下内容:
<?xml version="1.0"?>
<ArrayOfHeaderInfo xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<HeaderInfo>
<Key>NServiceBus.MessageId</Key>
<Value>7ffbe1e3-9b2c-456c-bcb7-a43d011a2389</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.CorrelationId</Key>
<Value>7ffbe1e3-9b2c-456c-bcb7-a43d011a2389</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.OriginatingEndpoint</Key>
<Value>NSB4Client</Value>
</HeaderInfo>
<HeaderInfo>
<Key>$.diagnostics.originating.hostid</Key>
<Value>75e8656bb268f44ded5f2a82b8798e6a</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.MessageIntent</Key>
<Value>Subscribe</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.Version</Key>
<Value>4.7.5</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.TimeSent</Key>
<Value>2015-02-12 17:07:14:158882 Z</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.OriginatingMachine</Key>
<Value>xxx</Value>
</HeaderInfo>
<HeaderInfo>
<Key>NServiceBus.ControlMessage</Key>
<Value>True</Value>
</HeaderInfo>
<HeaderInfo>
<Key>SubscriptionMessageType</Key>
<Value>MyMessages.EventMessage, MyMessages, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null</Value>
</HeaderInfo>
</ArrayOfHeaderInfo>
我假设这是因为标头在 4 和 2 之间不兼容,在这种情况下,我应该能够使用 mutator 转换为兼容格式,但是我尝试使用 mutator 拦截 NSB4 端点上的传出消息但它似乎没有截获消息(同时使用 IMutateTransportMessages 和 IMutateMessages)
2015-02-16 更新 根据https://groups.google.com/forum/#!topic/particularsoftware/XVLQkCouKCk,订阅的传出修改器似乎在 4.3 中被禁用,这可以解释为什么我的传出修改器解决方案不起作用
【问题讨论】:
-
NServicebus 是向后兼容的(不向前),因此您可能可以通过其他方式实现这一点......消息变异器可能存在错误。我正在尝试验证,并会通知您
标签: nservicebus