WCF 第五章 一个单一实例中的多线程

默认的InstanceContextMode行为设置指导WCF为每个请求创建一个新的服务实例。然后在很多情况下,这不是最好的解决方案。例如,如果一个服务有一个代价很高的例行初始化(比如,一个构造器从一个数据库读取数据或者创建一个大的内存结构),它对每个服务请求的实例创建都不是很高效。为了创建一个被当前线程共享的单一服务实例,InstanceContextMode.Single应该与ConcurrencyMode.Multiple结合使用。InstanceContextMode.Single意味着只能有一个实例被创建,而ConcurrencyMode.Multiple设置指导WCF在那个实例中同时执行多个线程。这可以提供一个重要的扩展性改进,但是服务代码必须处理同步来保护TLS(本地线程空间)。
  列表5.3显示了使用InstanceContextMode.Single和ConcurrencyMode.Multiple 行为的服务端代码。注意在类上的ServiceBehavior属性,不是接口。这是因为ServiceBehavior属性修改了服务行为,而不是它的契约。
  列表5.3使用InstanceContextMode.Single和ConcurrencyMode.Multiple的服务
    [ServiceContract]
    public interface IStockService
    {
        [OperationContract]
        double GetPrice(string ticker);
    }

    [ServiceBehavior(InstanceContextMode = InstanceContextMode.Single, ConcurrencyMode = ConcurrencyMode.Multiple)]
    public class StockService : IStockService
    {
        StockService()
        {
            Console.WriteLine("{0}:Created new instance of StockService on thread", DateTime.Now);
        }
        public double GetPrice(string ticker)
        {
            Console.WriteLine("{0}: GetPrice called on thread {1}", DateTime.Now, Thread.CurrentThread.ManagedThreadId);
            Thread.Sleep(5000);
            return 94.85;
        }
    }
  图片5.3显示了客户端(左边)和服务端(右边)的输出结果。与先前的例子一样,客户端输出显示三个请求同步发送而且结果在5秒钟后返回。服务端输出显示只有一个服务类的实例被创建,但是客户端请求仍然在它自己的线程中执行。InstanceContextMode.Single指导WCF只创建一个服务类的实例,而ConcurrencyMode.Multiple设置指导WCF允许多个线程在实例中并发的执行。


作者:DanielWise
出处:http://www.cnblogs.com/danielWise/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

原文地址:https://www.cnblogs.com/danielWise/p/1894886.html