zoukankan      html  css  js  c++  java
  • 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/
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    外键的创建
    MySQL (1366, "Incorrect string value: '\xF0\x9F\x8E\xAC\xE5\x89...' for column 'description' at row 1")
    python 获取文件路径
    ModuleNotFoundError: No module named 'Crypto'
    Django---错误
    CentOS7系统ifconfig无法使用的解决方法
    NACOS集群搭建遇到的问题
    Mysql连接报错:1130-host ... is not allowed to connect to this MySql server如何处理
    CentOS7 yum方式安装MySQL5.7
    MySQL数据库的全局锁和表锁
  • 原文地址:https://www.cnblogs.com/danielWise/p/1894886.html
Copyright © 2011-2022 走看看