WCF异步调用中客户端关闭带来的性能问题
这里的WCF异步调用是指单向非可靠异步调用,也就是你不知道调用是否成功,适用于性能高于可靠性的场合。
之前发布过一篇随笔WCF异步调用实战:OneWay+Asynchronous Operation,通过WCF服务端“单向(One-way)消息交换”+WCF客户端“异步信道调用(Asynchronous Operation)”实现快速的WCF异步调用。
但是,使用了一段时间,发现还是有些慢。今天实测了一下,调用代码如下:
var client = new ExternalService.FeedWcf.FeedServiceClient();
client.CreateAsync(...);
try { client.Close(); }
catch { client.Abort(); }
实测下来,上面的调用耗时100~300毫秒左右。慢!
当时有点想不明白,都已经异步了,怎么还会慢?
于是改为更直接的异步调用 —— Task.Factory.StartNew(),代码如下:
Task.Factory.StartNew(() =>
{
var client = new ExternalService.FeedWcf.FeedServiceClient();
client.CreateAsync(...);
try { client.Close(); }
catch { client.Abort(); }
});
实测下来,调用耗时0~5毫秒,这才是异步的效果。
WCF客户端的异步怎么了?查看WCF客户端代理类的代码,异步调用部分也没问题。
...
后来,恍然大悟,原来问题不在异步调用(client.CreateAsync),而是在WCF客户端的关闭(client.Close)。
于是,专门针对client.Close()进行测试,发现时间全耗在这里(100~300毫秒)!
目前还没找到“如何在异步调用时关闭WCF Client”的解决方法,先用Task.Factory.StartNew()凑合着,让WCF客户端在另外一个线程中慢慢关闭。