log4net.tools
1.2.0
See the version list below for details.
dotnet add package log4net.tools --version 1.2.0
NuGet\Install-Package log4net.tools -Version 1.2.0
<PackageReference Include="log4net.tools" Version="1.2.0" />
paket add log4net.tools --version 1.2.0
#r "nuget: log4net.tools, 1.2.0"
// Install log4net.tools as a Cake Addin #addin nuget:?package=log4net.tools&version=1.2.0 // Install log4net.tools as a Cake Tool #tool nuget:?package=log4net.tools&version=1.2.0
ForwardingAppenderAsync
Appender forwards LoggingEvents to a list of attached appenders asynchronously. It uses an internal queue and a worker task which dequeues items in background. The modes of handling the buffer overflow situation described here.
The example of the minimal xml configuration:
<appender name="ForwardingAppenderAsync" type="log4net.tools.ForwardingAppenderAsync">
<appender-ref ref="RollingFileAppender" />
</appender>
The example of the advanced xml configuration:
<appender name="ForwardingAppenderAsync" type="log4net.tools.ForwardingAppenderAsync">
<BufferSize value="1000"/>
<Fix value="260"/>
<BufferOverflowBehaviour value="RejectNew"/>
<BufferClosingType value="DumpToLog"/>
<appender-ref ref="DebugAppender" />
<appender-ref ref="RollingFileAppender" />
<appender-ref ref="AdoNetAppender" />
</appender>
RollingFileAppender Benchmark
10K of sequential info-logs:
Method | Mean |
---|---|
RollingFileAppender | 1,742.69 ms |
Buffered RollingFileAppender | 180.728 ms |
Forwarded RollingFileAppender | 5.43 ms |
10K of "parallel" (Parallel.For) info-logs:
Method | Mean |
---|---|
RollingFileAppender | 1,668.64 ms |
Buffered RollingFileAppender | 254.72 ms |
Forwarded RollingFileAppender | 4.45 ms |
AdoNetAppender Benchmark
10K of sequential info-logs:
Method | Mean |
---|---|
AdoNetAppender | 3,336.11 ms |
Forwarded AdoNetAppender | 5.54 ms |
10K of "parallel" (Parallel.For) info-logs:
Method | Mean |
---|---|
AdoNetAppender | 2,797.39 ms |
Forwarded AdoNetAppender | 4.62 ms |
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- log4net (>= 2.0.12)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on log4net.tools:
Package | Downloads |
---|---|
log4net.tools.integration
Tools for log4net: - MetricsCsvWriter writes logging metrics in a csv file. |
GitHub repositories
This package is not used by any popular GitHub repositories.
- handle closing of the appender when the buffer is not empty;
- update the error handling;
- update tests.