我正在使用功能应用程序(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)
然后我会看到异常消息,但没有堆栈跟踪。
答案 0 :(得分:1)
除了记录错误外,您还需要使用遥测客户端显式跟踪异常以获取异常详细信息。我在Web API 2.0中实现了ExceptionLogger,以使用跟踪异常方法将异常详细信息发送给app-insights。
var telemetry = new TelemetryClient();
...
try
{ ...
}
catch (Exception ex)
{
telemetry.TrackException(ex, properties, measurements);
}