3

我们在代码库中看到了以下堆栈跟踪:

System.ArgumentException: An item with the same key has already been added. 
   at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add) 
   at System.Net.Http.Headers.HttpHeaders.AddHeaderToStore(String name, HeaderStoreItemInfo info) 
   at System.Net.Http.Headers.HttpHeaders.SetParsedValue(String name, Object value) 
   at System.Net.Http.Headers.HttpContentHeaders.get_ContentLength() 
   at System.Net.Http.HttpClientHandler.PrepareAndStartContentUpload(RequestState state) 

并将其缩小到我们调用的代码中的某个地方

HttpContent.ReadAsStringAsync()

发生这种情况时,我们可以确定 HttpContent 的实例正被多个线程使用,所有线程都以某种方式试图读取实际内容。尚未弄清楚内容的阅读如何影响标题。

如果可以执行 HttpContent 的深度克隆,假设所有内容负载已下载,我们将研究此选项。

任何人都遇到过这个问题,如果是这样,你是如何解决的?

提前致谢。

4

1 回答 1

2

您的堆栈跟踪与阅读响应相关联对我来说毫无意义。似乎更有可能的是,在您发出请求之前,您有线程正在努力添加标头。也许与异步调试有些混淆?当我有这样的一行时,我已经看到了这一点(客户端是 HttpClient)

client.DefaultRequestHeaders.AcceptEncoding.Add(new System.Net.Http.Headers.StringWithQualityHeaderValue("gzip"));

在每个线程可以执行的代码上,它变成了一个竞争条件,因为我相信 httpclient 在添加它之前会检查是否存在,然后如果在这段时间之间有两个线程尝试添加它,它会像这样崩溃。根据您的设置,您可能需要将这样的内容移动到初始化中或在其周围加锁。

于 2017-06-06T19:28:15.997 回答