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.
172
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
75
Serilog.Sinks.Elasticsearch
Package Description
64
Serilog.Sinks.Elasticsearch
Package Description
62
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
60
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
59
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
57
Serilog.Sinks.Elasticsearch
Package Description
56
Serilog.Sinks.Elasticsearch
Package Description
55
Serilog.Sinks.Elasticsearch
Serilog sink for Elasticsearch
55
Serilog.Sinks.Elasticsearch
Package Description
54
Serilog.Sinks.Elasticsearch
Serilog.Sinks.Elasticsearch
52
Serilog.Sinks.AwsCloudWatch
A Serilog sink that logs to AWS CloudWatch
51
Serilog.Sinks.Elasticsearch
Package Description
50
Serilog.Sinks.Elasticsearch
Serilog.Sinks.Elasticsearch
49
Serilog.Sinks.Elasticsearch
Package Description
49
Serilog.Sinks.Elasticsearch
Package Description
48

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