这里的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客户端在另外一个线程中慢慢关闭。

相关文章:

  • 2021-08-30
  • 2021-09-02
  • 2021-05-30
  • 2022-12-23
  • 2021-11-14
  • 2022-12-23
猜你喜欢
  • 2021-06-11
  • 2021-09-01
  • 2022-01-07
  • 2021-07-25
  • 2022-12-23
  • 2022-12-23
  • 2022-01-31
相关资源
相似解决方案