Azure Function 崩溃的日志和内存转储在哪里?

时间:2021-04-07 07:53:19

标签: azure azure-functions

有时我的 azure 函数会失败并且我没有发生过的任何记录。函数只是停止执行。 我认为有像 StackOverflow 这样的重大错误,但由于没有记录,我无法确定。

我创建了一个简单的 azure 函数来模拟简单的堆栈溢出:

        public static async Task<IActionResult> Run(
            [HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)] HttpRequest req,
            ILogger log, ExecutionContext executionContext)
        {
             RunStackOverflow();
        }
          

        private static void RunStackOverflow()
        {
            RunStackOverflow();
        }

当我使用 http 触发器调用它时,我在浏览器中收到 502 错误,但日志中没有关于此失败的任何内容。截图:https://www.screencast.com/t/ymWoBey4KX

StackOverflow 只是无法捕获并可能导致函数崩溃的异常之一。在本地,当我在模拟器中运行该函数时,我在函数启动的 cmd 窗口中看到堆栈溢出错误。截图:https://www.screencast.com/t/f85U2KmdEBBt

在 Azure 门户中,我检查了:

但是在任何地方都没有此崩溃的日志条目。 我联系了 Azure 支持,但他们目前帮助不大。

4 月 12 日更新

使用 KUDU 我可以使用这样的命令创建内存转储 c:\devtools\sysinternals\procdump -e -ma -w 12268

这向我显示了所有线程的所有堆栈跟踪,这正是我所需要的,但仅限于第一次发生异常时。

出现异常时触发内存转储的命令是: c:\devtools\sysinternals\procdump -accepteula -e -g -ma 8844

但是当我运行它然后触发 StackOverflow 异常时,这是写到命令行的内容:

<块引用>

[11:37:36] 异常:E0434352.CLR

[11:37:36] 异常:C00000FD.STACK_OVERFLOW <--- 堆栈溢出

[11:37:37] 进程已经退出。

[11:37:37] 未达到转储计数。

遗憾的是没有创建内存转储,所以我看不到导致堆栈溢出的堆栈跟踪。

我也试过:

c:\devtools\sysinternals\procdump -accepteula -e -g -ma -t 13244

-t 选项在进程退出时触发内存转储。

这个实际上记录了函数崩溃时的内存转储。不幸的是,此转储不包括 StackOverflow 的堆栈跟踪。它似乎在线程崩溃后被转储。

4 月 21 日更新

这里描述的 Azure 函数有多种托管方式: https://docs.microsoft.com/en-us/azure/azure-functions/functions-scale

最常见和默认的方式是消费计划。经过一系列反复试验后,我发现可用于检测和分析崩溃的诊断工具 (https://www.screencast.com/t/DyT6Jpuqm2uo) 在消费计划中不可用。另一方面,它们可用于应用服务(基本和增强)和其他计划。 Azure 支持人员告诉我,目前没有将其添加到消费计划的计划。

所以现在我创建了一个使用应用服务计划托管的新 Azure 函数,并且我能够使用诊断工具来记录故障转储。解决问题后,我打算回到消费计划,所以这有点麻烦,但现在确实有效。

1 个答案:

答案 0 :(得分:1)

目前,对这种级别的日志的支持不是很好。

您可以按照 this link 使用 azure 门户中的 Diagnose and solve problems 选项,但请注意,此选项中的某些功能(如 Application Crashes)仍在开发中。

步骤:

1.在 azure 门户中 -> 您的函数应用 -> 单击 Diagnose and solve problems -> 然后单击 Function App Down or Reporting Errors 链接。截图如下:

enter image description here

2.在报告生成完成之前稍等片刻 -> 然后检查以 red exclamation mark 开头的项目(通过使用您的代码,错误详细信息在 Web App Restarted 项目中。但它只是显示像 app crashes,而不是 stackoverflow) 这样的常见消息:

enter image description here