我有一个使用jQuery的非常基本的JavaScript AJAX请求:
$.ajax({
type: "POST",
url: "TabbedSummaryPage.aspx/RunReport",
data: "{'itemId': '', 'lType': '', 'reportId': '', 'requestXml': ''}",
contentType: "application/json",
dataType: "json",
success: function (data, textStatus, jqXHR) {
},
error: function (jqXHR, textStatus, errorThrown) {
},
complete: function (jqXHR, textStatus) {
}
});
[WebMethod]
public static RunReportResponse RunReport(string itemId, string lType, string reportId, string requestXml)
{
var result = new RunReportResponse();
return result;
}
public struct RunReportResponse
{
public string reportTitle;
public string reportError;
public string reportHtml;
public string reportStyles;
public bool showWordMenu;
}
public class Global : System.Web.HttpApplication
{
}
我已经把所有东西都拆了下来,所以什么都没有真正被执行.
如果我发出多个并发的AJAX请求,就会发生奇怪的事情.
如果我发出11个请求,那么从响应中获取第一个字节的平均时间大约是50ms,但是其中5个总是花费2到3秒来响应第一个字节.
当我添加一些日志记录以查明发生了什么时,它似乎总是最后一组请求,无论我发送6个请求并获得3个慢速请求,或者我发送11个请求并获得5个慢速请求,它总是ASP.NET执行的最后一个请求,IIS向客户端提供的响应增加了1000毫秒.
我们有一个高性能应用程序,它依赖于毫不拖延地响应这些请求,因此我们必须弄清楚是什么导致了这种延迟.
在Internet Explorer 11,Chrome和Firefox中可以找到相同的测试结果.
不使用WebMethod属性的请求不会遇到此问题.
以下是请求期间发送的标头:
POST /pharmadotnet/Pharma/TabbedSummaryPage.aspx/RunReport HTTP/1.1
Host: localhost
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.0
Accept: application/json, text/javascript, */*; q=0.01
Accept-Language: en-GB,en;q=0.7,en-US;q=0.3
Accept-Encoding: gzip, deflate
Content-Type: application/json; charset=UTF-8
X-Requested-With: XMLHttpReques
Referer: http://localhost/pharmadotnet/Pharma/tabbedsummarypage.aspx?lType=coInfo&itemId=1293&compId=co&reportingCurrency=&sceName=&showTabs=
Content-Length: 223
Cookie: sTab=tabs-1; ASP.NET_SessionId=r01d2eqjxu0vdnexbl5mmd3p; curSessionId=r01d2eqjxu0vdnexbl5mmd3p; NewSession=true; __Antixsrftoken=ec03abb28ee14f50a18e34216aa59d85; .ASPXUSERDEMO=DF6CD4223C47DB289B82E0240DAB40AAF253BACE9A753863E77BA07F9CEE61D00235255A2BAA58F555ECF3166D8470E77654DB8C3E2594E54B5BAF38A5ACDCCA5FDED79ECD0B89DC3583B4F7E56911C15EE894365CA1444CF0A8D2AB8FEF19AA915CE3989F07DCFE6F4941DA69FBB38593BC51A9
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache
以下是其中一个请求的响应标头:
HTTP/1.1 200 OK
Cache-Control: private, max-age=0
Content-Type: application/json; charset=utf-8
Server: Microsoft-IIS/7.5
X-Powered-By: ASP.NET
Date: Tue, 08 Sep 2015 12:50:58 GMT
Content-Length: 174
无论我们是否正在调试,都会出现同样的问题.
IIS未配置为缓存请求.
WebForms页面未配置为缓存请求.
为什么会发生这种情况有什么特别的原因吗?
解决方法:
事实证明问题是会话锁定.
通过创建单独的WebForm,将EnableSessionState设置为false,并将Web方法移动到不使用会话的Web表单,我能够解决该问题.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。