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
49
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
47
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
45
Serilog.Sinks.Elasticsearch
Package Description
43
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
42
Serilog.Sinks.Elasticsearch
Package Description
41
Serilog.Sinks.Elasticsearch
Package Description
40
Serilog.Sinks.Elasticsearch
Package Description
39
Serilog.Sinks.Elasticsearch
Package Description
38
Serilog.Sinks.Elasticsearch
Package Description
37
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
34
Serilog.Sinks.Elasticsearch
Serilog.Sinks.Elasticsearch
34
Serilog.Sinks.Elasticsearch
Package Description
33
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
33
Serilog.Sinks.Elasticsearch
Package Description
32
Serilog.Sinks.MSSqlServerCore
DEPRECATED - Please use official Serilog sink for MSSqlServer as it now fully supports .NET Standard
31

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