Serilog.Sinks.PeriodicBatching 4.1.1-dev-00845

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.
118
Microsoft.Extensions.Logging.AzureAppServices
Logger implementation to support Azure App Services 'Diagnostics logs' and 'Log stream' features.
123
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
117
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
118
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
121
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
126
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
134
Serilog.Sinks.Http
A Serilog sink sending log events over HTTP.
162
Serilog.Sinks.Http
Serilog event sink that sends HTTP POST requests over the network.
119
Serilog.Sinks.Http
Serilog event sink that sends HTTP POST requests over the network.
122
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
118
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
120
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
121
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
127
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
130
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
132
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
146
Serilog.Sinks.PostgreSQL
Serilog sink for writing to PostgreSQL table
790

.NET Framework 4.6.2

.NET 6.0

.NET Standard 2.0

Version Downloads Last updated
5.0.1-dev-00860 118 07/18/2024
5.0.0 126 07/22/2024
5.0.0-dev-00855 118 07/23/2024
4.1.2-dev-00851 108 07/23/2024
4.1.1 123 07/23/2024
4.1.1-dev-00845 115 07/23/2024
4.1.0 124 07/23/2024
4.1.0-dev-00840 127 07/23/2024
4.0.2-dev-00838 129 07/23/2024
4.0.1 112 07/23/2024
4.0.1-dev-00832 111 07/23/2024
4.0.0 122 07/23/2024
4.0.0-dev-00824 107 07/23/2024
4.0.0-dev-00821 108 07/23/2024
3.1.1-dev-00804 111 07/21/2024
3.1.1-dev-00801 121 07/23/2024
3.1.0 123 07/23/2024
3.1.0-dev-00796 111 07/23/2024
3.0.0 100 07/23/2024
3.0.0-dev-00792 175 07/23/2024
2.3.1 117 07/23/2024
2.3.1-dev-00785 109 07/23/2024
2.3.1-dev-00780 140 07/23/2024
2.3.1-dev-00776 108 07/23/2024
2.3.1-dev-00774 129 07/23/2024
2.3.0 257 02/04/2024
2.3.0-dev-00765 122 07/23/2024
2.3.0-dev-00762 107 07/23/2024
2.3.0-dev-00760 119 07/23/2024
2.2.1-dev-00758 109 07/23/2024
2.2.1-dev-00755 108 07/23/2024
2.2.0 118 07/23/2024
2.2.0-dev-00748 125 07/23/2024
2.2.0-dev-00740 127 07/22/2024
2.1.1 112 07/21/2024
2.1.1-dev-00732 107 07/23/2024
2.1.1-dev-00729 142 07/23/2024
2.1.1-dev-00725 110 07/23/2024
2.1.0 121 07/23/2024
2.1.0-dev-00720 94 07/23/2024
2.0.2-dev-00719 107 07/23/2024
2.0.1 127 07/23/2024
2.0.1-dev-00714 132 07/23/2024
2.0.0 137 07/23/2024
2.0.0-rc-707 120 07/23/2024
2.0.0-rc-705 119 07/18/2024
2.0.0-beta-702 123 07/18/2024
2.0.0-beta-700 110 07/18/2024
2.0.0-beta-519 114 07/18/2024
2.0.0-beta-516 126 07/18/2024
2.0.0-beta-513 116 07/18/2024
2.0.0-beta-511 110 07/18/2024
2.0.0-beta-509 107 07/18/2024
2.0.0-beta-507 108 07/18/2024
2.0.0-beta-505 107 07/18/2024
2.0.0-beta-502 113 07/18/2024
2.0.0-beta-499 107 07/18/2024
2.0.0-beta-495 104 07/18/2024
2.0.0-beta-494 133 07/18/2024
2.0.0-beta-493 113 07/18/2024
2.0.0-beta-487 105 07/18/2024
2.0.0-beta-486 123 07/18/2024
2.0.0-beta-479 103 07/18/2024
2.0.0-beta-478 120 07/18/2024
2.0.0-beta-465 117 07/18/2024