码迷,mamicode.com
首页 > Web开发 > 详细

解决 .net HttpClient 调用时出现的 "A task was cancelled" 错误

时间:2017-11-28 11:54:00      阅读:1220      评论:0      收藏:0      [点我收藏+]

标签:直接   can   client   eth   读取   ima   删除   分析   文档   

近日在系统中集成ElasticClient客户端,自动创建索引、删除索引,发现通过 ElasticClient 的 LowerLevelClient 无法正确返回结果,但是索引已成功创建或删除。

并会在超时时间呢抛出异常”A task was cancelled“,查阅官方文档和Google都无解。

早上重新尝试,改用HttpClient直接进行访问,依然是一样的问题。

无奈,祭出Fiddler,进行请求分析。

1)使用Composer模拟请求,最简单的GET操作,居然也不能立即返回结果

技术分享图片

 

2)使用浏览器直接访问,能够正确返回结果

技术分享图片

 

3)比较Http 请求头,Fiddler 请求头基本都是空的,从浏览器复制Fiddler的请求头过来,最终发现,加上下面的请求头,就能正确返回结果:

Accept-Encoding: gzip, deflate

 技术分享图片

4)对应HttpClient来说,就可以用下面的方法解决了

HttpClientHandler handler = new HttpClientHandler()
            {
                AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate
            };

            var httpClient = new HttpClient(handler)
            {
                BaseAddress = new Uri($"http://{es_host}:{es_port}")
            };

使用这个HttpClient再去访问ElasticSearch,立即就能返回结果。

 

问题分析:服务器端默认情况下返回结果就会使用Gzip压缩,但是客户端默认不处理数据解压,就导致客户端读取数据时,无法判断数据是否已经读取完毕,就一直挂起,直到超时,然后抛出”A task was canceled" 错误。

 HttpClient 其他的 “A task was Canceled” 错误,很可能也是因为Http头设置不正确造成的,而服务器对客户端特性有要求,如本例的Gzip。 

 

 

解决 .net HttpClient 调用时出现的 "A task was cancelled" 错误

标签:直接   can   client   eth   读取   ima   删除   分析   文档   

原文地址:http://www.cnblogs.com/mobwiz/p/7908434.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!