我已将浏览器控件嵌入到 .Net 表单中,并将其编译为窗口的可执行文件。浏览器控件正在显示我们的 HTML5 图像查看器。该应用程序打开套接字,以便它可以侦听来自各个服务器的“推送”请求。这允许将图像推送到单个用户的桌面。
当传入图像推送请求时,应用程序使用 RESTSharp 调用 REST 服务来生成令牌,供查看器用来显示图像。
只要请求不断到达,一切都会很好。如果出现间歇(时间范围似乎是 10 分钟),则 RESTSharp 请求就会超时。这几乎就像是在尝试 .Net 优化时创建 RESTSharp 工件的新实例并重用旧实例。
这是我正在使用的 RESTSharp 代码:
private async Task<string> postJsonDataToUrl(string lpPostData) {
IRestClient client = new RestClient(string.Format("{0}:{1}", MstrScsUrlBase, MintScsUrlPort));
IRestRequest request = new RestRequest(string.Format("{0}{1}{2}", MstrScsUrlContextRoot, MstrScsUrlPath, SCS_GENERATE_TOKEN_URL_PATH));
request.Timeout = 5000;
request.ReadWriteTimeout = 5000;
request.AddParameter("application/json", lpPostData, ParameterType.RequestBody);
IRestResponse response = await postResultAsync(client, request);
return response.Content;
} // postJsonDataToUrl
private static Task<IRestResponse> postResultAsync(IRestClient client, IRestRequest request) {
return client.ExecutePostTaskAsync(request);
} // PostResultAsync
这是发生超时的行:
IRestResponse response = await postResultAsync(client, request);
我尝试使用 .Net 的 HttpWebRequest 重写它,但遇到了同样的问题。
如果我延长 RESTSharp 超时,我就可以在应用程序“超时”时调用服务器(使用不同的客户端),因此我知道服务器不是问题所在。
代码的初始版本没有等待异步调用结构 - 添加该结构是为了尝试获取有关该问题的更多信息。
除了 REST 超时之外,我没有收到任何错误。
我通过此调用强制进行垃圾收集的成功有限:
GC.Collect(GC.MaxGeneration, GCCollectionMode.Forced);
有什么想法吗?