Azure Web应用程序以及扩展的Azure功能允许按照“诊断日志”配置部分中的配置将日志消息发送到Blob存储。
但是,传递给C#函数(v2)实现的默认ILogger实例将忽略该设置。取而代之的是,您似乎需要手动构建一个记录器才能使用此功能,如下所示。请注意,您需要从NuGet添加Microsoft.Extensions.Logging.AzureAppServices
进行编译。
[FunctionName("myfun")]
public static async Task<IActionResult> Run(
[HttpTrigger(AuthorizationLevel.Function, "get", "post", Route = null)]HttpRequest req,
ILogger log)
{
log.LogInformation("This does not end up in the app log.");
var factory = new LoggerFactory().AddAzureWebAppDiagnostics();
var log2 = factory.CreateLogger("MyFun");
log2.LogInformation("This *does* end up in the app log, if configured.");
log2.LogError("Fake error for testing logging functionality (2)");
}
我的问题:有没有更优雅的方法来获取记录器,该记录器写入已配置的App Log Blob存储?我希望传递给该函数的
log
已经具有此功能(可能是通过观察已配置的应用程序日志触发的),但是默认情况下它没有,并且我看不到如何添加的清晰路径既不通过配置也不用其他方式替换ILogger log
参数。 最佳答案
对于Azure Function V2,您可以使用注入(inject)的ILogger记录所有日志作为应用程序见解,然后可以从azure门户转到应用程序应用程序> Application Insights>然后选择Analytics(日志)>然后可以使用此查询来检索所有日志:
traces
where appName == "YourAppName"
对于旧功能V2,可以使用注入(inject)的traceWriter并将其与任何记录器集成,以便可以在与此功能应用程序相关的自动创建的Blob存储表中找到日志,并可以使用Microsoft Azure存储资源管理器轻松对其进行检查。
关于c# - 如何在Azure Functions V2中登录到Azure应用日志?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/52538272/