我有很多Web服务,当它们被调用时,它们需要在返回之前调用其他外部服务来获取信息.这一切都是同步完成的.
因此,如果我有一个返回电影列表的电影GET服务,Web服务逻辑将等待电影提供商的外部服务返回数据,处理它并返回GET的数据.
将外部服务调用包装在Task中并使用async / await模型可以证明它有什么好处吗?处理GET的初始线程是否仍然只是被阻塞等待响应,还是会被释放来处理其他传入的服务调用?
解决方法
Would it prove to be any benefit by wrapping the external service call in a Task and use the async/await model?
包装同步调用可能不会带来太多好处 – 但如果外部服务提供真正的异步API,您可以获得显着的好处.
Wouldn’t the initial thread handling the GET still just be blocked waiting for the response or would it be freed up to handle other incoming service calls?
我不知道WCF目前对async的支持是什么样的,但是应该可以编写所有这些内容,以便在实际工作完成时只有任何线程处于活动状态…所以你可以处理数百个只有几个线程的请求.如果您的任何外部服务调用相对较慢,这一点尤为重要.
所以基本上,有收获,但你应该分别考虑两个方面: