zoukankan      html  css  js  c++  java
  • WCF InstanceContextMode and ConcurrencyMode

    I recently ran into a concurrency issue with WCF on a customer's system. I'll get into the details later (though not too much detail... NDA ;) ), but it involved some testing of the various combinations of InstanceContextMode and ConcurrencyMode settings for a WCF service. The table below is an attempt to clarify the results...


    InstanceContextMode
    ConcurrencyMode
    Resulting Behaviour
    PerCall
    Single
    • New InstanceContext created per call
    • Calls processed concurrently, because each call gets it's own instance

    Multiple
    Same as with ConcurrencyMode.Single
    PerSession
    Single
    • New InstanceContext is created for each client proxy connection
    • Each call is pooled and processed serially in a FIFO manner

    Multiple
    • New InstanceContext is created for each client proxy connection
    • Each call is processed as soon as it arrives
    • A single instance of the proxy is required for concurrent processing from a single client
    Singlton
    Single
    • Single instance of an InstanceContext
    • Each call is pooled and processed serially in a FIFO manner

    Multiple
    • Single instance of an InstanceContext
    • Each call is processed as soon as it arrives
    • The developer must manage thread-safety


    It's also worth noting that if you are using ServiceHost in an executable assembly, that the Main() method not be marked with the single threaded appartment attribute [System.STAThreadAttribute()]. This causes the application to be single threaded, and the additional threads will not be created regardless of the ConcurrencyMode.Multiple setting. Rather, it should be decorated with the multi-threaded appartment attribute [System.MTAThreadAttribute()].

    作者:Angelo Lee
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
  • 相关阅读:
    Daliy Algorithm (dp,模拟)-- day 80
    Daliy Algorithm (dp,堆)-- day 79
    Mybatis一级缓存和二级缓存 Redis缓存
    简单排序
    java一个大接口拆用多线程方式拆分成多个小接口
    集群环境下Shiro Session的管理
    递归和快速排序
    分布式定时任务
    Redis集群架构
    IO流
  • 原文地址:https://www.cnblogs.com/yefengmeander/p/2887740.html
Copyright © 2011-2022 走看看