C# 如何使控制器动作真正异步
我有以下控制器:C# 如何使控制器动作真正异步,c#,async-await,asp.net-web-api2,C#,Async Await,Asp.net Web Api2,我有以下控制器: public class PingController : ApiController { [Route("api/ping")] [HttpGet] public IHttpActionResult Ping() { var log = HostLogger.Get(typeof(PingController)); log.Info("Ping called."); return Ok("Pin
public class PingController : ApiController
{
[Route("api/ping")]
[HttpGet]
public IHttpActionResult Ping()
{
var log = HostLogger.Get(typeof(PingController));
log.Info("Ping called.");
return Ok("Ping succeeded @ " + DateTime.UtcNow);
}
[Route("api/long-ping")]
[HttpGet]
public async Task<IHttpActionResult> LongPing(CancellationToken cancelToken)
{
await Task.Delay(30 * 1000);
return Ok("Ping succeeded @ " + DateTime.UtcNow);
}
}
公共类PingController:ApiController
{
[路线(“api/ping”)]
[HttpGet]
公共IHttpActionResult Ping()
{
var log=HostLogger.Get(typeof(PingController));
log.Info(“Ping调用”);
返回Ok(“Ping成功@”+DateTime.UtcNow);
}
[路线(“api/龙坪”)]
[HttpGet]
公共异步任务LongPing(CancellationToken cancelToken)
{
等待任务。延迟(30*1000);
返回Ok(“Ping成功@”+DateTime.UtcNow);
}
}
如果我在不同的浏览器选项卡中执行LongPing,然后执行Ping,Ping将在LongPing之前执行并返回,这正是我要寻找的。问题是,当我执行两个隆平调用时,第二个调用大约需要60秒才能完成(而不是30秒)。Chrome报告第二次呼叫的延迟为58秒(60秒减去我启动第二次请求的时间)。在我看来,如果我让它正常工作,两个隆平调用都应该在30秒左右执行
我还应该提到,我是在OWIN托管环境中托管的,而不是IIS。但我不认为这有什么区别,但也许有人会证明我错了
如何使LongPing的行为真正像一个异步请求?很可能是您的会话状态导致了您的问题。对于这种行为有一个冗长的解释,但简短的解释是,一个特定的用户会话一次只能执行一个请求,因为会话状态锁定以确保状态一致。如果您想加快速度,请禁用cookie以测试会话状态假设(这样,每个请求将获得1个会话状态),或者在应用程序中禁用会话状态。您的代码在其他方面是异步的。事实证明,这是Chrome在调用同一URL时的行为。在使用Chrome进行测试时,我总是忘记这一点。通常我使用Fiddler进行测试,但是这个VM没有Fiddler 见此问答:
禁用会话状态如果这是使用IIS中托管的标准MVC,我可能会同意。但这是一个控制台托管的OWIN应用程序,使用WebAPI,默认情况下没有打开会话(我认为这是正确的)。