Serilog logging for ASP.NET Core. This package routes ASP.NET Core log messages through Serilog, so you can get information about ASP.NET's internal operations logged to the same Serilog sinks as your application events.
First, install the Serilog.AspNetCore NuGet package into your app. You will need a way to view the log messages - Serilog.Sinks.Console writes these to the console; there are many more sinks available on NuGet.
Install-Package Serilog.AspNetCore -DependencyVersion Highest
Install-Package Serilog.Sinks.Console
Next, in your application's Program.cs file, configure Serilog first:
public class Program
{
public static int Main(string[] args)
{
Log.Logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.MinimumLevel.Override("Microsoft", LogEventLevel.Information)
.Enrich.FromLogContext()
.WriteTo.Console()
.CreateLogger();
Then, add UseSerilog()
to the web host builder. A try
/catch
block will ensure any configuration issues are appropriately logged:
try
{
Log.Information("Starting web host");
var host = new WebHostBuilder()
.UseKestrel()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.UseSerilog() // <-- Add this line
.Build();
host.Run();
return 0;
}
catch (Exception ex)
{
Log.Fatal(ex, "Host terminated unexpectedly");
return 1;
}
finally
{
Log.CloseAndFlush();
}
}
}
Finally, clean up by removing the remaining configuration for the default logger:
- Remove calls to
AddLogging()
- Remove the
"Logging"
section from appsettings.json files (this can be replaced with Serilog configuration as shown in this example, if required) - Remove
ILoggerFactory
parameters and anyAdd*()
calls on the logger factory in Startup.cs - Remove
UseApplicationInsights()
(this can be replaced with the Serilog AI sink, if required)
That's it! With the level bumped up a little you will see log output like:
[22:14:44.646 DBG] RouteCollection.RouteAsync
Routes:
Microsoft.AspNet.Mvc.Routing.AttributeRoute
{controller=Home}/{action=Index}/{id?}
Handled? True
[22:14:44.647 DBG] RouterMiddleware.Invoke
Handled? True
[22:14:45.706 DBG] /lib/jquery/jquery.js not modified
[22:14:45.706 DBG] /css/site.css not modified
[22:14:45.741 DBG] Handled. Status code: 304 File: /css/site.css
Tip: to see Serilog output in the Visual Studio output window when running under IIS, select ASP.NET Core Web Server from the Show output from drop-down list.
With Serilog.AspNetCore installed and configured, you can write log messages directly through Serilog or any ILogger
interface injected by ASP.NET. All loggers will use the same underlying implementation, levels, and destinations.