c# - 异常 - 堆栈跟踪行号和消息不匹配

标签 c# nservicebus

当出现问题时,我们会发现一些代码出现奇怪的问题 - 在某些情况下,异常消息和堆栈跟踪不匹配。

我们有许多具有类似结构的消息处理程序,如下所示:

public void Handle(AddTelephoneNumber message)
{
    var directory = ClientService.Directory(Context).Result;

    var client = ClientService.ClientLookup(message.ClientNumber, Context).Result;
    if (!client.Item1)
    {
        //Client does not exist
        throw new Exception("Unable to locate client"); //A
    }
    //B Start
    var clientPersonsLnk = client.Item2.Links.Single(l => l.Rel == "client-persons");
    var persons = ClientService.Get<Persons>(clientPersonsLnk.Uri, Context).Result;
    var person = ClientService.Get<Person>(persons.PartyUri(message.Party), Context).Result;
    var phones = ClientService.Get<TelephoneNumbers>(person.Links.Single(l => l.Rel == "person-telephones").Uri, Context).Result;
    var addPhoneLink = phones.Links.Single(l => l.Rel == "telephone-add");

    var newPhone = new TelephoneNumber();
    //Set up the new telephone number, elided from sample
    //B End

    var result = ClientService.Post(addPhoneLink.Uri, newPhone, Context).Result;
    if (result.Item1 == HttpStatusCode.OK || result.Item1 == HttpStatusCode.Created)
        return;
    else
        _logger.WarnFormat("ClientService.Post to {0} returned unexpected response code of: {1}", addPhoneLink.Uri, result.Item1);

    //C
    throw new Exception("Unable to process telephone number addition message");
}

我们观察到的行为如下 - 如果 A 或 C 之一发生,我们不可避免地会得到最终传递到错误队列的消息,消息扩展中包含以下信息:

<HeaderInfo>
    <Key>NServiceBus.ExceptionInfo.Message</Key>
    <Value>Unable to process change person name message</Value>
</HeaderInfo>
<HeaderInfo>
    <Key>NServiceBus.ExceptionInfo.Source</Key>
    <Value>ProjectName</Value>
</HeaderInfo>
<HeaderInfo>
    <Key>NServiceBus.ExceptionInfo.StackTrace</Key>
    <Value>System.Exception: Unable to process change person name message
    at ProjectName.Handlers.ChangePersonNameHandler.Handle(ChangePersonName message) in c:\TeamCity\buildAgent\work\6601b33332f54f3c\ProjectName\Handlers\ChangePersonNameHandler.cs:line 45
    at NServiceBus.Unicast.HandlerInvocationCache.Invoke(Object handler, Object message, Dictionary`2 dictionary) in c:\TeamCity\buildAgent\work\d4de8921a0aabf04\src\NServiceBus.Core\Unicast\HandlerInvocationCache.cs:line 63
    at NServiceBus.Unicast.UnicastBus.&lt;&gt;c__DisplayClass2f.&lt;DispatchMessageToHandlersBasedOnType&gt;b__2a(Action dispatch) in c:\TeamCity\buildAgent\work\d4de8921a0aabf04\src\NServiceBus.Core\Unicast\UnicastBus.cs:line 1093</Value>
</HeaderInfo>

(很抱歉切换到不同的消息类型 -​​ 我只是想找一个例子)

不过,似乎包含的是,如果异常消息与在点 A 给出的异常相匹配,则堆栈跟踪,特别是这一行:

at ProjectName.Handlers.ChangePersonNameHandler.Handle(ChangePersonName message) in c:\TeamCity\buildAgent\work\6601b33332f54f3c\ProjectName\Handlers\ChangePersonNameHandler.cs:line 45

将始终包含 C 点异常的行号。反之亦然,如果我们得到应在 C 行生成的异常消息,则堆栈跟踪的行号将指向 A 行。

B 部分中的方法抛出的任何异常似乎都忠实地报告了正确的行号。因此,似乎直接在处理程序中抛出的异常具有这种奇怪的行为,但我们调用的代码抛出的任何异常(例如,如果序列不包含任何元素,则从 Linq 抛出)的行为与往常一样。

除了难以置信地喋喋不休之外,有谁知道有什么可以导致这种转变发生的吗?

来自 packages.config:

  <package id="NServiceBus" version="4.0.1" targetFramework="net45" />
  <package id="NServiceBus.CastleWindsor" version="4.0.1" targetFramework="net45" />
  <package id="NServiceBus.Host" version="4.0.1" targetFramework="net45" />
  <package id="NServiceBus.Interfaces" version="4.0.1" targetFramework="net45" />
  <package id="NServiceBus.NHibernate" version="4.0.1" targetFramework="net45" />

或者我应该做进一步的调查,向问题添加更多信息等吗?

最佳答案

1)

private void SomeMethod ( )
{
    try { //some code here }
    catch ( Exception е) 
    {
         throw е : / / CLR thinks that the exception line is there.
    }
}

2)也可能是C#编译器优化引起的,尝试在你的方法中添加属性检查一下:

 [Methodlmpl(MethodImplOptions.Noinlining)]

3) 您是否在使用隐藏实现细节异常模式?

我个人认为是因为编译器优化,因为它可以换行和优化代码。

关于c# - 异常 - 堆栈跟踪行号和消息不匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19583863/

相关文章:

c# - Response.write 和目标框架

c# - 使用 SMO 还原对象还原差异备份

c# - 如何抛出异常以强制消息进入 NServiceBus 中的错误队列

NServiceBus 4.0 的 RavenDB 错误

NServiceBus:System.Transactions.TransactionException:合作伙伴事务管理器已禁用其对远程/网络事务的支持

c# - 如何为 WPF 命令绑定(bind)编写测试?

c# - C# 和 CPython 之间快速且可扩展的 RPC

c# - 如何在c#中删除解密中的填充

nservicebus - 零停机 NServiceBus 升级

asp.net - NServiceBus 在 Web/MVC4 + SQL 架构中有用吗?