Azure ASP .net WebApp请求超时

时间:2016-07-30 11:16:48

标签: c# asp.net-mvc azure

我已将ASP .net MVC Web应用程序部署到Azure App服务。

我从我的站点向一些控制器方法发出GET请求,该方法从DB(DbContext)获取数据。有时,从数据库获取数据的过程可能需要4分钟以上。这意味着我的请求没有超过4分钟的动作。之后,Azure终止连接 - 我收到消息:

  

500 - 请求超时。

Web服务器失败   在指定时间内作出回应。

这是一个方法示例:

 [HttpGet]
    public async Task<JsonResult> LongGet(string testString)
    {            
       var task = Task.Delay(360000);
        await task;            
        return Json("Woke", JsonRequestBehavior.AllowGet);
    }

我见过很多像这样的问题,但我没有回答:

Not working 1 不能给其他链接 - 声誉太低。

我已经阅读了这个article - 它关于Azure负载均衡器,它不适用于webapps,但是它写的是在Azure webapp中处理我的问题的常用方法是使用TCP Keep-alive。所以我改变了我的方法:

[HttpGet]
    public async Task<JsonResult> LongPost(string testString)
    {
        ServicePointManager.SetTcpKeepAlive(true, 1000, 5000);
        ServicePointManager.MaxServicePointIdleTime = 400000;
        ServicePointManager.FindServicePoint(Request.Url).MaxIdleTime = 4000000;
       var task = Task.Delay(360000);
        await task;            
        return Json("Woke", JsonRequestBehavior.AllowGet);
    }

但仍然得到同样的错误。 我正在使用简单的GET请求,如

GET /Home/LongPost?testString="abc" HTTP/1.1
Host: longgetrequest.azurewebsites.net
Cache-Control: no-cache
Postman-Token: bde0d996-8cf3-2b3f-20cd-d704016b29c6

所以我正在寻找答案我做错了什么以及如何在Azure Web应用程序中增加请求超时时间。任何帮助表示赞赏。

门户网站上的Azure设置:

网络套接字 - 开启

永远开启 - 开启

应用设置:

SCM_COMMAND_IDLE_TIMEOUT = 3600

WEBSITE_NODE_DEFAULT_VERSION = 4.2.3

2 个答案:

答案 0 :(得分:37)

230秒。而已。这是Azure App Service中的飞行中请求超时。它在平台上是硬编码的,所以TCP保持不变,你仍然受它约束。

来源 - 请参阅David Ebbo的回答:
https://social.msdn.microsoft.com/Forums/en-US/17305ddc-07b2-436c-881b-286d1744c98f/503-errors-with-large-pdf-file?forum=windowsazurewebsitespreview

  

对于未发送任何数据的请求,有230秒(即少于4分钟)超时。之后,客户端获得您看到的500,即使实际上允许请求继续服务器端。

在不了解您的应用程序的情况下,很难提出不同的方法。然而,很明显,你确实需要一种不同的方法 -

也许返回type N = Int 而不是202 Accepted标题,以便稍后轮询结果?

答案 1 :(得分:-3)

我刚刚将我的Azure网站从共享环境更改为标准版,它可以正常运行。