isx*_*pjm 6 .net c# asp.net-web-api dotnet-httpclient
我有一个像这样的 Web API 控制器:
[Route("api/[controller]")]
public class SlowController : Controller
{
[HttpPost]
public ActionResult Post([FromBody]SlowRequest request)
{
var response = new SlowResponse();
response.Id = request.Id;
response.StartDate = DateTime.Now;
Thread.Sleep(new TimeSpan(0, 3, 0));
response.EndDate = DateTime.Now;
return Ok(response);
}
}
Run Code Online (Sandbox Code Playgroud)
请注意如何有 3 分钟的睡眠。这是为了模拟post动作需要很长时间才能返回。
我有一个调用此 Web API 的客户端控制台应用程序:
static void Main(string[] args)
{
try
{
var request = new SlowRequest();
request.Id = Guid.NewGuid();
var json = JsonConvert.SerializeObject(request);
var httpClient = new HttpClient();
httpClient.Timeout = new TimeSpan(0, 5, 0);
httpClient.BaseAddress = new Uri("http://localhost:54316/");
var result = httpClient.PostAsync("api/slow", new StringContent(json, Encoding.UTF8, "application/json")).Result.EnsureSuccessStatusCode();
var apiResponse = result.Content.ReadAsStringAsync().Result;
var response = JsonConvert.DeserializeObject<SlowResponse>(apiResponse);
Console.WriteLine("Start Time = " + response.StartDate);
Console.WriteLine("End Time = " + response.EndDate);
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
Run Code Online (Sandbox Code Playgroud)
不幸的是,客户端在 2 分钟后抛出异常说:
响应状态代码不表示成功:502(坏网关)。
似乎如果 API 需要超过 2 分钟来返回这个,就会发生异常。不到 2 分钟,它工作得很好。尽管事实上我已经在客户端上设置了 5 分钟的超时时间。如何防止需要很长时间的 Web API 调用出现这样的错误?
问题不是来自客户端,而是来自服务器。你让它休眠 3 分钟,这超过了默认的请求超时。您可以在 web.config 中更改它:
<aspNetCore requestTimeout="00:05:00" ... />
Run Code Online (Sandbox Code Playgroud)
请注意,该值只能以整分钟指定,否则默认为 2 分钟。请参阅核心配置参考。
Kersel 也有 2 分钟的超时时间,您需要更改Program.cs
:
.UseKestrel(o => o.Limits.KeepAliveTimeout = TimeSpan.FromMinutes(5));
Run Code Online (Sandbox Code Playgroud)
注意:我假设您的项目是 Core。如果不是这种情况,您必须更改executionTimeout
web.config 中的属性。默认为 110 秒:
<system.web>
<httpRuntime executionTimeout="300" />
</system.web>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
7420 次 |
最近记录: |