ILogger.LogError不记录异常详细信息

时间:2019-05-09 13:31:58

标签: azure azure-functions azure-application-insights

我正在使用功能应用程序(2.0版),并尝试记录异常的堆栈跟踪。

     try
        {
            processedOrder = await orderProcessingService.ProcessOrder(order);
        }
        catch (Exception ex)
        {
            log.LogError(ex, $"Error processing order: {order.Id}");
        }

这仅将消息记录在App Insights中,但不记录有关传递的异常对象的信息。

我这样做正确吗?

如果我愿意 log.LogError(ex, $"Error processing order: {order.Id}", ex)然后我会看到异常消息,但没有堆栈跟踪。

1 个答案:

答案 0 :(得分:1)

除了记录错误外,您还需要使用遥测客户端显式跟踪异常以获取异常详细信息。我在Web API 2.0中实现了ExceptionLogger,以使用跟踪异常方法将异常详细信息发送给app-insights。

var telemetry = new TelemetryClient();
    ...
    try
    { ...
    }
    catch (Exception ex)
    {       
       telemetry.TrackException(ex, properties, measurements);
    }