Serilog.Sinks.PeriodicBatching 4.1.2-dev-00851

Serilog.Sinks.PeriodicBatching Build status NuGet Version

A wrapper for Serilog sinks that asynchronously emits events in batches, useful when logging to a slow and/or remote target.

Getting started

Sinks that, for performance reasons, need to emit events in batches, can be implemented using PeriodicBatchingSink from this package.

First, install the package into your Sink project:

dotnet add package Serilog.Sinks.PeriodicBatching

Then, instead of implementing Serilog's ILogEventSink, implement IBatchedLogEventSink in your sink class:

class ExampleBatchedSink : IBatchedLogEventSink
{
    public async Task EmitBatchAsync(IEnumerable<LogEvent> batch)
    {
        foreach (var logEvent in batch)
            Console.WriteLine(logEvent);
    }
    
    public Task OnEmptyBatchAsync() { }
}

Finally, in your sink's configuration method, construct a PeriodicBatchingSink that wraps your batched sink:

public static class LoggerSinkExampleConfiguration
{
    public static LoggerConfiguration Example(this LoggerSinkConfiguration loggerSinkConfiguration)
    {
        var exampleSink = new ExampleBatchedSink();
        
        var batchingOptions = new PeriodicBatchingSinkOptions
        {
            BatchSizeLimit = 100,
            Period = TimeSpan.FromSeconds(2),
            EagerlyEmitFirstEvent = true,
            QueueLimit = 10000
        };
        
        var batchingSink = new PeriodicBatchingSink(exampleSink, batchingOptions);
        
        return loggerSinkConfiguration.Sink(batchingSink);
    }
}

Showing the top 20 packages that depend on Serilog.Sinks.PeriodicBatching.

Packages Downloads
Microsoft.Extensions.Logging.AzureAppServices
Logger implementation to support Azure App Services 'Diagnostics logs' and 'Log stream' features.
36
Serilog.Sinks.Email
Send Serilog events as SMTP email using MailKit.
36
Serilog.Sinks.Email
Send Serilog events as SMTP email using MailKit.
43
Serilog.Sinks.Email
The file sink for Serilog
30
Serilog.Sinks.Email
The file sink for Serilog
37
Serilog.Sinks.Seq
A Serilog sink that writes events to Seq using newline-delimited JSON and HTTP/HTTPS.
40
Serilog.Sinks.Seq
Serilog sink that writes to the Seq event server over HTTP/S.
30
Serilog.Sinks.Seq
Serilog sink that writes to the Seq event server over HTTP/S.
33
Serilog.Sinks.Seq
Serilog sink that writes to the Seq event server over HTTP/S.
34
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
30
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
32
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
33
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
35
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
60
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
97
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
179
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
338
Serilog.Sinks.Seq
Serilog sink that writes to the Seq log server over HTTP/HTTPS.
480

.NET Framework 4.6.2

.NET 6.0

.NET Standard 2.0

Version Downloads Last updated
5.0.1-dev-00860 37 07/06/2024
5.0.0 28 06/06/2024
5.0.0-dev-00855 25 06/07/2024
4.1.2-dev-00851 31 06/04/2024
4.1.1 28 05/29/2024
4.1.1-dev-00845 28 05/27/2024
4.1.0 34 05/12/2024
4.1.0-dev-00840 22 05/12/2024
4.0.2-dev-00838 27 05/12/2024
4.0.1 32 03/15/2024
4.0.1-dev-00832 29 03/15/2024
4.0.0 33 03/13/2024
4.0.0-dev-00824 37 02/08/2024
4.0.0-dev-00821 38 02/08/2024
3.1.1-dev-00804 23 02/08/2024
3.1.1-dev-00801 33 02/08/2024
3.1.0 159 10/10/2022
3.1.0-dev-00796 42 02/08/2024
3.0.0 58 09/20/2022
3.0.0-dev-00792 26 02/08/2024
2.3.1 85 04/15/2022
2.3.1-dev-00785 28 02/08/2024
2.3.1-dev-00780 30 02/08/2024
2.3.1-dev-00776 28 02/08/2024
2.3.1-dev-00774 34 02/08/2024
2.3.0 505 02/26/2021
2.3.0-dev-00765 27 02/08/2024
2.3.0-dev-00762 33 02/08/2024
2.3.0-dev-00760 29 02/08/2024
2.2.1-dev-00758 29 02/08/2024
2.2.1-dev-00755 25 02/08/2024
2.2.0 34 02/10/2020
2.2.0-dev-00748 30 02/08/2024
2.2.0-dev-00740 31 02/08/2024
2.1.1 32 07/04/2020
2.1.1-dev-00732 32 02/08/2024
2.1.1-dev-00729 27 02/08/2024
2.1.1-dev-00725 39 02/08/2024
2.1.0 34 02/08/2024
2.1.0-dev-00720 29 02/08/2024
2.0.2-dev-00719 28 02/08/2024
2.0.1 33 02/08/2024
2.0.1-dev-00714 28 02/08/2024
2.0.0 47 02/08/2024
2.0.0-rc-707 32 02/08/2024
2.0.0-rc-705 30 02/08/2024
2.0.0-beta-702 27 02/08/2024
2.0.0-beta-700 30 02/08/2024
2.0.0-beta-519 26 02/08/2024
2.0.0-beta-516 28 02/08/2024
2.0.0-beta-513 33 02/08/2024
2.0.0-beta-511 28 02/08/2024
2.0.0-beta-509 29 02/08/2024
2.0.0-beta-507 33 02/08/2024
2.0.0-beta-505 27 02/08/2024
2.0.0-beta-502 25 02/08/2024
2.0.0-beta-499 30 02/08/2024
2.0.0-beta-495 23 02/08/2024
2.0.0-beta-494 26 02/08/2024
2.0.0-beta-493 30 02/08/2024
2.0.0-beta-487 32 02/08/2024
2.0.0-beta-486 33 02/08/2024
2.0.0-beta-479 36 02/08/2024
2.0.0-beta-478 34 02/08/2024
2.0.0-beta-465 30 02/08/2024