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