奇怪的 WCF net.tcp 异常

Posted

技术标签:

【中文标题】奇怪的 WCF net.tcp 异常【英文标题】:Strange WCF net.tcp exception 【发布时间】:2011-04-07 15:15:32 【问题描述】:

我有一个带有 net.tcp 传输的 WCF 客户端/服务。当我在客户端打开 WCF 跟踪时,我在跟踪中看到以下错误(请参阅服务跟踪查看器的屏幕截图)。奇怪的是,WCF 正在处理和恢复这个错误,而我的客户端没有收到任何异常并且它继续工作。此异常经常发生,随机发生,但不是在每个 Web 方法调用中发生。 客户端(windows XP)身份验证是windows,服务由SPN标识,服务自托管在NLB(windows server 2003)后面的windows服务上。 谁能解释一下这里发生了什么。

来自跟踪 xml 的异常堆栈跟踪是:

<ExceptionString>
System.ServiceModel.Security.MessageSecurityException: The server rejected the upgrade request. ---&gt; System.ServiceModel.ProtocolException: Error while reading message framing format at position 0 of stream (state: ReadingUpgradeRecord) ---&gt; System.IO.InvalidDataException: More data was expected, but EOF was reached.
   --- End of inner exception stack trace ---
   --- End of inner exception stack trace ---
</ExceptionString>

:

【问题讨论】:

作为背景,我们的一些用户报告了许多异常,我正在调查为什么只有一些 PC 似乎有它。因此,我在自己的 PC 上启动了服务跟踪,我很惊讶,因为客户端从未收到这些异常,WCF 正在吞噬它们。我在想如果这个 MessageSecurityException 最终导致一些客户端得到真正的异常。一些客户端记录此异常:无法连接到 net.tcp://myservice:9501/SomeService。连接尝试持续了 00:00:21.3873440 的时间跨度。 TCP 错误代码 10060: 你提到了 NLB。您是否使用粘性会话(会话亲和性)? 否 NLB 会话关联在端口规则中为无。该服务正在使用具有 2 分钟空闲超时和 1 分钟租赁超时的自定义 net.tcp 绑定。但是我发现我们不小心使用了 persession instancecontextmode,因为有人认为这是默认设置。我会尽快将其更改为 percall。 【参考方案1】:

不确定真正的问题可能是什么,以及它是否与流媒体有关(我会深入探讨)。无论如何,您可以尝试在服务器端捕获异常并抛出 CommunicationException

catch (Exception ex)

    throw new CommunicationException(ex.Message, ex);

这样客户端代理不应该忽略异常并且它的状态应该是“故障”。

【讨论】:

以上是关于奇怪的 WCF net.tcp 异常的主要内容,如果未能解决你的问题,请参考以下文章

除非客户端和服务器使用相同的 Windows 身份,否则带有 sspi 的 WCF Net.tcp 会失败

在从 net.tcp 协议连接到 WCF 的端点处侦听的问题

服务器拒绝了会话建立请求:WCF 托管在 IIS 上

继续Wcf记录点滴

net.tcp 使用(显然)Solid .config <systerm.serviceModel> 引发异常

从第三方 WCF 获取底层异常 - SOAP 异常