WCF中的CallContext

dra*_*fly 7 .net c# wcf multithreading

当请求到达WCF服务时使用CallContext是安全的,用一些调用特定数据初始化它(例如在调用开始时使用钩子:Inspector/ContextBoundObject),然后在调用中重用它,并保证数据I访问一直是相同的数据?

谢谢,Pawel

Qua*_*ter 7

如果您没有从检查员那里使用它,那么它应该是安全的,但如果您不使用Remoting或跨越AppDomain边界,那么仅使用线程静态字段可能更简单.将ThreadStaticAttribute放在静态字段上,它将是每个线程中的单独存储位置.

IDispatchMessageInspector例如,如果您尝试在a中设置值,那么它将无法工作,因为它们将在与请求不同的线程中运行.看一下OperationContext,它将提供有关WCF请求的特定于呼叫的信息.您可以通过实现IExtension<OperationContext>并将它们添加到Extensions属性来添加可以存储自定义数据的扩展. 这是一篇博客文章,介绍如何将自定义数据添加到OperationContext.

  • 我工作的应用程序中的遗留代码是在WCF操作中的CallContext中存储特定于用户的状态.由于我们的WCF服务托管在IIS中,因此不同的WCF操作在不同的线程上运行,这些线程可从IIS线程池重用.我们注意到一些零星的行为,其中某些操作正在获取与其他用户相关的用户数据.这是由于代码错误地使用CallContext而不是OperationContext,它仅在WCF操作的生命周期内有效.这是一个很难追踪的,但转换到OperationContext解决了它. (4认同)