【发布时间】: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. ---> System.ServiceModel.ProtocolException: Error while reading message framing format at position 0 of stream (state: ReadingUpgradeRecord) ---> 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。
标签: wcf tcp wcf-security