WCF 第五章 控制并发调用的数量

当InstancingMode设置成Single时,WCF在宿主内创建一个单一的实 例,不考虑有多少客户端被创建。当ConcurrencyMode设置成Multiple时,WCF为每个请求创建一个线程(取决于系统上限)以实现服务 方法的并行执行。为了减少这个,maxConcurrentCalls行为控制有多少个并发调用可以激活。

  列表5.9 显示了一个使用InstanceContextMode.Single和ConcurrencyMode.Multiple的服务行为。服务操作花费20秒完成。

 列表5.9 使用InstanceContextMode.Single和ConcurrencyMode.Multiple的行为的服务

01 [ServiceContract]
02 public interface IStockService
03 {
04     [OperationContract]
05     double GetPrice(string ticker);
06 }
07  
08 [ServiceBehavior(InstanceContextMode= InstanceContextMode.Single, ConcurrencyMode=ConcurrencyMode.Multiple)]
09 public class StockService : IStockService
10 {
11     StockService()
12     {
13         Console.WriteLine("{0}:Created new instance of StockService on thread", DateTime.Now);
14     }
15     public double GetPrice(string ticker)
16     {
17         Console.WriteLine("{0}: GetPrice called on thread {1}", DateTime.Now, Thread.CurrentThread.ManagedThreadId);
18         Thread.Sleep(20000);
19         return 94.85;
20     }
21 }

  列表5.10 显示了服务的app.config文件。maxConcurrentCalls行为设置成5,意味着在同一时间不可以再激活多于5个调用。

列表5.10 使用maxConcurrentCalls控制并发

01 "1.0" encoding="utf-8" ?>
02
03     
04         
05         
06             
07                 "throttling">
08                   "5"/>
09                 
10             
11         
12         
13             "throttling" name="Services.StockService">
14                 "" binding="basicHttpBinding" contract="Services.IStockService" />
15                 
16                     
17                         "http://localhost:8000/stockservice" />
18                     
19                 
20             
21         
22     
23

图片5.7显示了列表5.7中的客户端(左边)和服务端(右边)输出。在客户端,注意当程序启动时10次调用立即开始。在这10次调用中,5个结果 在20秒钟后返回而剩下的5个结果在另外20秒钟后返回。在服务端输出,注意只有一个实例被创建。也要注意5次对GetPrice的调用立刻执行,每个都 在它们自己的线程里执行。当这5个线程结束后,线程被重用同时客户端的顺序请求被处理。

WCF 第五章 控制并发调用的数量_第1张图片

图片5.7 控制并发调用数量的输出结果


========

转载自

作者: DanielWise
出处: http://www.cnblogs.com/danielWise/
 

转载于:https://www.cnblogs.com/llbofchina/archive/2011/06/30/2094056.html

你可能感兴趣的:(WCF 第五章 控制并发调用的数量)