Adding Serilog to an application and pointing it at Seq
Firstly, let's add all the NuGet packages we'll need:
- Serilog.AspNetCore
- Serilog.Enrichers.Environment
- Serilog.Enrichers.Process
- Serilog.Enrichers.Thread
- Serilog.Settings.Configuration
- Serilog.Sinks.Seq
Create a new file called serilog.json and populate it with the following, replacing the serverUrl and apiKey (or completely removing that element if not required).
{
"Serilog": {
"Using": [],
"MinimumLevel": {
"Default": "Information",
"Override": {
"Microsoft": "Warning",
"System": "Warning"
}
},
"Enrich": [ "FromLogContext", "WithMachineName", "WithProcessId", "WithThreadId" ],
"WriteTo": [
{
"Name": "Seq",
"Args": {
"serverUrl": "http://seq.yourdomain.com:5341",
"apiKey": "YourApiKey"
}
},
{ "Name": "Console" }
]
}
}
Next we'll modify Main in Program.cs. If all your Main methods contains is CreateHostBuilder(args).Build().Run(); then you can simply replace the contents with the following:
var loggingConfiguration = new ConfigurationBuilder()
.AddJsonFile("serilog.json")
.AddEnvironmentVariables()
.Build();
Log.Logger = new LoggerConfiguration()
.ReadFrom.Configuration(loggingConfiguration)
.CreateLogger();
try
{
Log.Information("Application starting up");
CreateHostBuilder(args).Build().Run();
}
catch(Exception ex)
{
Log.Fatal(ex, "Application start failed");
}
finally
{
Log.CloseAndFlush();
}
Then, in the CreateHostBuilder method, after Host.CreateDefaultBuilder(args)
add the following:
.UseSerilog()
Finally, if you want to log requests, in the Configure method of Startup.cs, before app.UseRouting()
, add the following line:
app.UseSerilogRequestLogging();
If you encounter any missing usings, use Ctrl+. and add them as needed.
Don't forget to inject and use an ILogger instance of your controllers to log errors, warnings, etc…
The last thing to do is remove the Logging section from appsettings.json.
If you want to override the API key with an environment variable, for example as part of a deployment process, you would use the following variable name:
Serilog__WriteTo__0__Args__apiKey
If you want to exclude health checks from request logging, Andrew Lock's blog has a great solution. I've packaged this in a NuGet package, Serilog.Extras
, along with a couple of enrichers that I required. Note this package is targeting .NET 6.
Once you've referenced the above NuGet package, replace:
app.UseSerilogRequestLogging();
With the following:
app.UseSerilogRequestLoggingWithoutHealthChecks();
You'll also need to add a using for Serilog.Extras to enable this extension.
The two enrichers are WithVersionNumber
and WithDeploymentEnvironment
which add the values of the environment variables VERSION_NUMBER
and ASPNETCORE_ENVIRONMENT
respectively to your output logs.