有时我的 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 函数,并且我能够使用诊断工具来记录故障转储。解决问题后,我打算回到消费计划,所以这有点麻烦,但现在确实有效。
答案 0 :(得分:1)
目前,对这种级别的日志的支持不是很好。
您可以按照 this link 使用 azure 门户中的 Diagnose and solve problems
选项,但请注意,此选项中的某些功能(如 Application Crashes
)仍在开发中。
步骤:
1.在 azure 门户中 -> 您的函数应用 -> 单击 Diagnose and solve problems
-> 然后单击 Function App Down or Reporting Errors
链接。截图如下:
2.在报告生成完成之前稍等片刻 -> 然后检查以 red exclamation mark
开头的项目(通过使用您的代码,错误详细信息在 Web App Restarted
项目中。但它只是显示像 app crashes
,而不是 stackoverflow
) 这样的常见消息: