当前位置: 首页 > 知识库问答 >
问题:

Azure Application Insights中没有异常或堆栈跟踪

何升
2023-03-14

我试过大多数设置日志记录/应用程序洞察遥测的组合,下面是我试过的一些东西:

    Startup.csConfigureReservices()方法中的 Services.AddApplicationInsightSteLemetry();
  1. logging.addApplicationInsights();添加到program.cs
  2. 中的日志生成器
  3. 删除自定义错误页异常处理程序,以防发生影响事件

我在Azure中的Web应用程序上设置了AppInsights_InstrumentationKey环境变量。

我正在使用以下代码生成应用程序洞察中的异常:

[AllowAnonymous]
[Route("autoupdate")]
public async Task<IActionResult> ProfileWebhook()
{
    var formData = await this.Request.ReadFormAsync();

    var config = TelemetryConfiguration.CreateDefault();
    var client = new TelemetryClient(config);

    client.TrackException(new Exception(string.Join("~", formData.Keys)));
    logger.LogError(new Exception(string.Join("~", formData.Keys)), "Fail");
    throw new Exception(string.Join("~", formData.Keys));
}

一切都不起作用了,我快疯了!非常感谢任何帮助。

共有1个答案

伯英锐
2023-03-14

通常,应用洞察将保证所有类型的遥测(如异常、跟踪、事件等)将在5分钟左右到达,请参阅此文档:遥测收集需要多长时间?。但仍有可能由于beckend问题而需要更长的时间(极小的几率)。

如果使用的是visual studio,则可以通过Application Insights搜索检查遥测是否发送。

您还可以检查是否使用了正确的IKey,或者是否启用了采样。

但是如果它将这种行为留在你的身边,你应该考虑联系MS支持以找到根本原因。

希望有帮助。

 类似资料:
  • 问题内容: 这可能是一个非常幼稚的问题。 我曾经相信Java 中的a 总是 包含堆栈跟踪。这是正确的吗? 现在看起来我捕获了 没有 堆栈跟踪的异常。是否有意义?是否 可以 在没有堆栈跟踪的情况下捕获异常? 问题答案: 无需堆栈跟踪就可以捕获Java中的Throwable对象: 构造一个具有指定详细消息,原因,启用或禁用原因,启用或禁用 可写堆栈跟踪 的新throwable 。 填写执行堆栈跟踪。此

  • 现在看来,我在没有堆栈跟踪的情况下捕获异常。有道理吗?是否有可能在没有堆栈跟踪的情况下捕获异常?

  • Edit2 @Paradematic在建议重定向而不是抛出异常方面做得很好;这解决了日志记录问题。Play 2中的问题是,重定向需要发生在所谓的范围内,而日期解析器调用并不总是这样。 最初的 有一个问题,即我的application.log被与uri日期解析器操作相关的错误填满,如果给定有效的uri日期,该操作应该成功。 然而,一些用户试图通过输入无效日期来规避这一点,希望获得免费访问付费订阅者专

  • 问题内容: 如何将异常的堆栈跟踪信息打印到stderr以外的流上?我发现的一种方法是使用getStackTrace()并将整个列表打印到流中。 问题答案: 可以接受or或参数: 也就是说,请考虑将SLF4J之类的记录器接口与LOGBack或log4j之类的记录实现一起使用。

  • 问题内容: 是否有一种特殊的机制来强制scrapy打印出所有python异常/堆栈跟踪。 我犯了一个简单的错误,即弄错了一个列表属性,导致AttributeError出现,该错误未在日志中完整显示: 因此它显示的AttributeError计数为1,但是没有告诉我在哪里以及如何进行操作,我不得不手动在代码中放置ipdb.set_trace()来找出哪里出错了。Scrapy本身继续执行其他线程而不打

  • 问题内容: 我的类的实例变量之一正在发生某些事情。我想将变量设置为属性,并且每当访问该变量时,我都希望打印出导致该点的所有代码的堆栈跟踪,因此我可以看到它的混乱之处。没有异常发生时如何打印堆栈跟踪?我知道是否有例外,我可以做类似的事情。 同样有用的是仅打印最后3-4个级别,因为前几个级别可能不会那么有趣。 问题答案: : 编辑:您还可以使用extract_stack,获取一个切片(例如,排除前5个