Serilog.Sinks.PeriodicBatching 5.0.1-dev-00860

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.

[!IMPORTANT] Serilog 4.x and later versions support batching natively. New projects should use Serilog's IBatchedLogEventSink and WriteTo.Sink(IBatchedLogEventSink), not this package which is now only maintained for compatibility reasons.

Updating for Serilog v4+

First, update your Serilog package reference to the latest published version.

This example is from Serilog.Sinks.Postgresql.Alternative. Old code:

var batchingOptions = new PeriodicBatchingSinkOptions()
{
    BatchSizeLimit = postgresOptions.BatchSizeLimit,
    Period = postgresOptions.Period,
    QueueLimit = postgresOptions.QueueLimit
};

var batchingSink = new PeriodicBatchingSink(new PostgreSqlSink(postgresOptions), batchingOptions);
return sinkConfiguration.Sink(batchingSink, restrictedToMinimumLevel, levelSwitch);

New code:

var batchingOptions = new BatchingOptions()
{
    BatchSizeLimit = postgresOptions.BatchSizeLimit,
    BufferingTimeLimit = postgresOptions.Period,
    QueueLimit = postgresOptions.QueueLimit
};

return sinkConfiguration.Sink(
    new PostgreSqlSink(postgresOptions), batchingOptions, restrictedToMinimumLevel, levelSwitch);

When you're done, don't forget to remove the Serilog.Sinks.PeriodicBatching package dependency.

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
Serilog.Sinks.AmazonKinesis
Serilog event sink that writes to Amazon Kinesis.
146
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
59
Serilog.Sinks.Elasticsearch
Package Description
48
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
46
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
44
Serilog.Sinks.Elasticsearch
Package Description
41
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
40
Serilog.Sinks.Elasticsearch
Package Description
38
Serilog.Sinks.Elasticsearch
Package Description
37
Serilog.Sinks.Elasticsearch
Package Description
36
Serilog.Sinks.Elasticsearch
Package Description
34
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
33
Serilog.Sinks.Elasticsearch
Serilog.Sinks.Elasticsearch
33
Serilog.Sinks.Elasticsearch
Package Description
32
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
32
Serilog.Sinks.Elasticsearch
Serilog.Sinks.Elasticsearch
30
Serilog.Sinks.Elasticsearch
Package Description
30

.NET Framework 4.6.2

.NET Framework 4.7.1

.NET 6.0

.NET 8.0

.NET Standard 2.0

Version Downloads Last updated
5.0.1-dev-00860 8 07/06/2024
5.0.0 7 06/07/2024
5.0.0-dev-00855 7 06/08/2024
4.1.2-dev-00851 8 06/01/2024
4.1.1 23 05/31/2024
4.1.1-dev-00845 7 05/24/2024
4.1.0 23 05/15/2024
4.1.0-dev-00840 12 05/16/2024
4.0.2-dev-00838 8 05/16/2024
4.0.1 15 03/18/2024
4.0.1-dev-00832 7 03/19/2024
4.0.0 14 03/18/2024
4.0.0-dev-00824 13 02/09/2024
4.0.0-dev-00821 11 02/09/2024
3.1.1-dev-00804 21 06/02/2023
3.1.1-dev-00801 11 08/30/2023
3.1.0 13 08/24/2023
3.1.0-dev-00796 48 06/01/2023
3.0.0 28 08/24/2023
3.0.0-dev-00792 11 08/30/2023
2.3.1 16 08/31/2023
2.3.1-dev-00785 13 08/26/2023
2.3.1-dev-00780 11 08/30/2023
2.3.1-dev-00776 14 09/09/2023
2.3.1-dev-00774 11 08/27/2023
2.3.0 15 08/25/2023
2.3.0-dev-00765 9 08/31/2023
2.3.0-dev-00762 21 08/25/2023
2.3.0-dev-00760 8 08/30/2023
2.2.1-dev-00758 11 05/18/2023
2.2.1-dev-00755 9 08/26/2023
2.2.0 17 08/28/2023
2.2.0-dev-00748 20 08/25/2023
2.2.0-dev-00740 20 08/30/2023
2.1.1 75 07/01/2020
2.1.1-dev-00732 10 08/26/2023
2.1.1-dev-00729 10 08/30/2023
2.1.1-dev-00725 7 02/15/2024
2.1.0 138 05/07/2021
2.1.0-dev-00720 16 08/27/2023
2.0.2-dev-00719 42 05/17/2023
2.0.1 8 08/29/2023
2.0.1-dev-00714 13 08/30/2023
2.0.0 39 11/25/2019
2.0.0-rc-707 13 08/30/2023
2.0.0-rc-705 33 08/25/2023
2.0.0-beta-702 21 08/29/2023
2.0.0-beta-700 13 08/27/2023
2.0.0-beta-519 12 08/27/2023
2.0.0-beta-516 9 08/31/2023
2.0.0-beta-513 17 08/26/2023
2.0.0-beta-511 18 08/28/2023
2.0.0-beta-509 22 08/25/2023
2.0.0-beta-507 13 05/18/2023
2.0.0-beta-505 11 09/01/2023
2.0.0-beta-502 9 08/27/2023
2.0.0-beta-499 9 08/29/2023
2.0.0-beta-495 10 08/26/2023
2.0.0-beta-494 14 12/07/2023
2.0.0-beta-493 9 08/28/2023
2.0.0-beta-487 19 08/25/2023
2.0.0-beta-486 10 05/17/2023
2.0.0-beta-479 12 08/31/2023
2.0.0-beta-478 18 08/30/2023
2.0.0-beta-465 12 08/26/2023