Tal*_*umy 1 c# asp.net asp.net-web-api
我有一个 Web API C# 项目。我注意到当向控制器发送很少的请求时(很少有甚至 7-10 个),一些请求需要很长时间(5-7 秒)。单独发送每个请求时,每个请求耗时不到200ms。我正在向我的本地主机(开发环境)发送请求,因此服务器上不应该有任何延迟或大量使用。
我在 global.asax 中添加了这段代码,以查看每个请求需要多长时间。
//Global asax
private Dictionary<string, StopWatch> urlTimers = new Dictionary<string, StopWatch>();
void Application_BeginRequest(object sender, EventArgs e)
{
HttpContextBase currentContext = new HttpContextWrapper(HttpContext.Current);
var requestedUrl = currentContext.Request.RequestContext.HttpContext.Request.RawUrl;
var urlWithoutQueryParams = requestedUrl.Split('?')[0];
if (urlWithoutQueryParams.StartsWith("/controller"))
{
var stopWatch = new StopWatch();
stopWatch.Start(urlWithoutQueryParams);
urlTimers[urlWithoutQueryParams] = stopWatch;
}
}
void Application_EndRequest(object sender, EventArgs e)
{
HttpContextBase currentContext = new HttpContextWrapper(HttpContext.Current);
var requestedUrl = currentContext.Request.RequestContext.HttpContext.Request.RawUrl;
var urlWithoutQueryParams = requestedUrl.Split('?')[0];
if (urlWithoutQueryParams.StartsWith("/controller"))
{
var stopWatch = urlTimers[urlWithoutQueryParams];
if (stopWatch != null)
{
stopWatch.Stop();
}
}
}
Run Code Online (Sandbox Code Playgroud)
使用提琴手提交 10 个请求时,我收到以下信息
所有请求都返回少量数据,因此也不应该是问题所在。10 个请求花费这么多时间是没有意义的。任何帮助将不胜感激。
小智 5
我会假设这还不是 MVC 6 Web Api(存在 Global.asax 和所有),而是 MVC 5 或更低版本。人们在 MVC 5 Web API 中忘记的一件事是 SessionState。一些关于此的简短博客:
简而言之,归结为:
启用 SessionState 后,每个用户会话一次仅处理一个请求。在您的情况下,这意味着:
它们都是同时请求的,因此它们具有相同的开始时间。但是,请求的结束时间取决于先前请求所需的时间 + 它自己的处理时间。这会导致样本中每次调用的时间增加。
如果您的操作不访问会话信息,您可以“安全地”[SessionState(SessionStateBehavior.ReadOnly)]
在控制器上添加该属性(请参阅博客)。这将导致同时处理调用。只是不要在更改会话信息的控制器上使用它。