c# - WebMethod 性能变慢

标签 c# asp.net ajax

我有一个使用 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) {
    }
});

正在调用和执行以下 C# 代码:

[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 个请求,从响应中获取第一个字节的平均时间约为 50 毫秒,但其中 5 个请求总是需要 2 到 3 秒来响应第一个字节。

当我添加一些日志记录以了解发生了什么时,它似乎总是最后一组请求,无论我发送 6 个请求并返回 3 个慢请求,还是发送 11 个请求并返回 5 个慢请求,它始终是 ASP.NET 执行的最后一个请求,IIS 向客户端提供额外的 1000+ 毫秒响应。

我们有一个高性能应用程序,它依赖于立即响应这些请求,因此我们必须找出导致这种延迟的原因。

在 Internet Explorer 11、Chrome 和 Firefox 中发现了相同的测试结果。

不使用 WebMethod 属性的请求不会遇到此问题。

以下是请求期间发送的 header :

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

以下是其中一个请求的响应 header :

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 页面未配置为缓存请求。

为什么会发生这种情况有什么特别的原因吗?

最佳答案

原来是 session 锁定的问题。

通过创建一个单独的 WebForm,将 EnableSessionState 设置为 false,并将 web 方法移动到不使用 session 的 web 表单,我能够工作围绕这个问题。

关于c# - WebMethod 性能变慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32458729/

相关文章:

javascript - On Keyup 值正在被解析。如何在 jQuery 自动完成中设置这些值?

c# - DapperORM中 'SELECT CAST(SCOPE_IDENTITY() as int)'的重要性

Docker 上的 Asp.Net Core

Javascript AJAX 函数返回类型未定义

javascript - 为什么包装我的 JS SignalR 回调我的 $(function() 使其不被触发?

asp.net - 如何关闭 Azure 网站中的 302 重定向

javascript - AngularJS:AJAX 返回的是字符串而不是对象

c# - 使用 SqlBulkCopy 连接到 SQLite 数据库

c# - 如何比较两个 System.Types?

c# MVC - 文件夹结构 - 在哪里放类?