I can't seem to get Trace level log information outputted after upgrading to .NET Core 2.0 (+ASP.NET Core 2.0).
In fact, if I do a dotnet new web
project and add the code below in Startup for Configure, I do not get any trace or debug log messages, but I get the Information and Error messages twice. Commenting out the .AddConsole()
call will output these (Information and Error) only once - suggesting that it gets configured automatically with a console provider by default. Keep in mind, this is a "File -> New" project experience, there is nothing setup in Program.cs
for logging or configuration at all for this - except for what I've added. Anyone seen things? Or should I register a GitHub issue for it.
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) { loggerFactory.AddConsole(Microsoft.Extensions.Logging.LogLevel.Trace); if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.Run(async (context) => { var logger = loggerFactory.CreateLogger("Blah"); logger.LogTrace("Hello world : Trace"); logger.LogDebug("Hello world : Debug"); logger.LogInformation("Hello world : Information"); logger.LogError("Hello world : Error"); await context.Response.WriteAsync("Hello World!"); }); }
NLog is one of the most popular, and one of the best-performing logging frameworks for . NET. Setting up NLog is fairly simple. Developers can use Nuget to download the dependency, then edit the NLog.
In ASP.NET Core, logging providers store the logs. You can configure multiple logging providers for your application. The default ASP.NET Core configures the following logging providers: Console, Debug, EventSource, and EventLog (on Windows).
The way logging is configured has changed a little... The recommended way (and it's pretty well documented in this GitHub issue/announcement to do it now is to configure the loggers on the AddLogging
method, such as
services.AddLogging(builder => { builder.AddConfiguration(Configuration.GetSection("Logging")) .AddConsole() .AddDebug(); });
And have an appsettings.json
like
Seems a few people are confused, because the example only demonstrates the configuration of Console
provider and not all loggers.
The LogLevel
section configures logging level for all namespaces (Default
key) or for a specific namespace (System
overrides the default value for all classes logging whose namespace starts with System.*
.
This is for the class used in T
in ILogger<T>
). This allows to set a higher or lower than default logging level for loggers from this namespace.
{ "ApplicationInsights": { "InstrumentationKey": "" }, "Logging": { "IncludeScopes": false, "LogLevel": { "Default": "Information", "System": "Warning", "Microsoft": "Information" }, "Console": { "LogLevel": { "Default": "Warning", "System": "Information", "Microsoft": "Information" } } } }
Please note that the structure of the appsettings.json changed from what it used to be in .NET Core 1.x and that Logging
entry in the appsettings.json
now has logger provider names in it, which allows you to configure logging levels per logging provider.
Previously, the entry in appsettings.json
would only be applicable to the console logger.
Alternatively, the logging can now be moved within the WebHostBuilder
instead.
public static void Main() { var host = new WebHostBuilder() .UseKestrel() .UseContentRoot(Directory.GetCurrentDirectory()) .ConfigureAppConfiguration((hostingContext, config) => { var env = hostingContext.HostingEnvironment; config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true) .AddJsonFile("hosting.json", optional: false) .AddEnvironmentVariables(); }) .ConfigureLogging((webhostContext, builder) => { builder.AddConfiguration(webhostContext.Configuration.GetSection("Logging")) .AddConsole() .AddDebug(); }) .UseIISIntegration() .UseStartup<Startup>() .UseApplicationInsights() .Build(); host.Run(); }
In case one doesn't want to use the appsettings.json
, one can register the filters in code too.
services.AddLogging(builder => { builder.AddConfiguration(Configuration.GetSection("Logging")) // filter for all providers .AddFilter("System", LogLevel.Debug) // Only for Debug logger, using the provider type or it's alias .AddFilter("Debug", "System", LogLevel.Information) // Only for Console logger by provider type .AddFilter<DebugLoggerProvider>("System", LogLevel.Error) .AddConsole() .AddDebug(); });
I spent almost twenty minutes to realize that since Configuration.GetSection("Logging")
in the Startup.cs file reads the section "Logging"
from the config in the appsettings.json file, which was configured as "Error"
. Changing it to "Information"
or anything lower, fixed the issue.
Here's what the appsettinsg.json file looks now:
{ "Logging": { "IncludeScopes": true, "Debug": { "LogLevel": { "Default": "Information" } }, "Console": { "LogLevel": { "Default": "Information" } } } }
To find out more about the levels of logging (such as in "Information"
), check out this link, that also provides general information on ASP.NET Core logging.
I'm just posting here, just in case you bump into any trouble with getting the logging to work, make sure you've been through that JSON file.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With