All notable changes to this project will be documented in this file.
This project adheres to Semantic Versioning and is following the change log format.
-
#311 [BREAKING CHANGE] Support specifying
levelSwitch
when creating the sink, thus adding the support to dynamically change the log level at runtime (contribution by @yuriy-millen)Migration guide
The parameter
levelSwitch
has been introduced to the methodsHttp
,DurableHttpUsingFileSizeRolledBuffers
andDurableHttpUsingTimeRolledBuffers
. Please verify that the arguments pass by you to these methods still align with your intentions.To automatically mitigate this kind of new parameter issue in the future, move from using positional arguments to named arguments instead.
-
#116 [BREAKING CHANGE] Support specifying
batchSizeLimitBytes
when creating the sink, thus limiting the size of the payloads sent to the log server (proposed by @michaeltdaniels)Migration guide
The parameter
batchSizeLimitBytes
has been introduced to the methodsHttp
,DurableHttpUsingFileSizeRolledBuffers
andDurableHttpUsingTimeRolledBuffers
. Please verify that the arguments pass by you to these methods still align with your intentions.To automatically mitigate this kind of new parameter issue in the future, move from using positional arguments to named arguments instead.
-
#166 Support for content encoding Gzip using HTTP client
JsonGzipHttpClient
(contribution by @vaibhavepatel, @KalininAndreyVictorovich and @AntonSmolkov) -
#166 Support for specifying
HttpClient
when creatingJsonHttpClient
andJsonGzipHttpClient
-
#166 [BREAKING CHANGE] Interface
IHttpClient
has changed to accommodate for different HTTP content typesMigration guide
You'll have to migrate your code if you've implemented your own version of
IHttpClient
. The signature of methodIHttpClient.PostAsync
has changed fromTask<HttpResponseMessage> PostAsync(string, HttpContent)
toTask<HttpResponseMessage> PostAsync(string, Stream)
.// Before migration public class MyHttpClient : IHttpClient { // Code removed for brevity... public async Task<HttpResponseMessage> PostAsync(string requestUri, HttpContent content) { // Here you probably have some code updating the content, // and then you send the request return await httpClient.PostAsync(requestUri, content) } } // After migration public class MyHttpClient : IHttpClient { // Code removed for brevity... public async Task<HttpResponseMessage> PostAsync(string requestUri, Stream contentStream) { using (var content = new StreamContent(contentStream)) { content.Headers.Add("Content-Type", "application/json"); // Here you probably have some code updating the content, // and then you send the request return await httpClient.PostAsync(requestUri, content) } } }
-
#162 [BREAKING CHANGE] Deprecated dependency Serilog.Sinks.RollingFile has been removed (discovered by @tipasergio)
Migration guide
You'll have to migrate your code if you're using
DurableHttpUsingTimeRolledBuffers
, i.e. use the durable HTTP sink with a rolling behavior defined by a time interval. The parameterbufferPathFormat
has been renamed tobufferBaseFileName
, and the parameterbufferRollingInterval
has been added.Given you are configuring the sink in code you should apply the following changes.
// Before migration log = new LoggerConfiguration() .WriteTo.DurableHttpUsingTimeRolledBuffers( requestUri: "https://www.mylogs.com", bufferPathFormat: "MyBuffer-{Hour}.json") .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.DurableHttpUsingTimeRolledBuffers( requestUri: "https://www.mylogs.com", bufferBaseFileName: "MyBuffer", bufferRollingInterval: BufferRollingInterval.Hour) .CreateLogger();
Given you are configuring the sink in application configuration you should apply the following changes.
// Before migration { "Serilog": { "WriteTo": [ { "Name": "DurableHttpUsingTimeRolledBuffers", "Args": { "requestUri": "https://www.mylogs.com", "bufferPathFormat": "MyBuffer-{Hour}.json" } } ] } } // After migration { "Serilog": { "WriteTo": [ { "Name": "DurableHttpUsingTimeRolledBuffers", "Args": { "requestUri": "https://www.mylogs.com", "bufferBaseFileName": "MyBuffer", "bufferRollingInterval": "Hour" } } ] } }
-
#206 [BREAKING CHANGE] Argument
bufferFileSizeLimitBytes
to extension methodsDurableHttpUsingFileSizeRolledBuffers
andDurableHttpUsingTimeRolledBuffers
no longer accepts0
as value -
#203, #245 [BREAKING CHANGE] Non-durable sink has changed from having its maximum queue size defined as number of events into number of bytes, making it far easier to reason about memory consumption. It's importance to the behavior of the sink was also the reasoning for promoting it from being optional to being mandatory. (proposed by @seruminar)
Given you are limiting the queue in code you should do the following changes.
// Before migration log = new LoggerConfiguration() .WriteTo.Http( requestUri: "https://www.mylogs.com", queueLimit: 1000) .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.Http( requestUri: "https://www.mylogs.com", queueLimitBytes: 50 * ByteSize.MB) .CreateLogger();
Given you are limiting the queue in application configuration you should do the following changes.
// Before migration { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com", "queueLimit": 1000 } } ] } } // After migration { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com", "queueLimitBytes": 52428800 } } ] } }
Given you aren't limiting the queue in code you should do the following changes.
// Before migration log = new LoggerConfiguration() .WriteTo.Http(requestUri: "https://www.mylogs.com") .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.Http( requestUri: "https://www.mylogs.com", queueLimitBytes: null) .CreateLogger();
Given you aren't limiting the queue in application configuration you should do the following changes.
// Before migration { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com" } } ] } } // After migration { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com", "queueLimitBytes": null } } ] } }
-
#171 [BREAKING CHANGE] Move maximum log event size configuration from batch formatter to sink configuration, and change it's default value from 256 kB to
null
Migration guide
Given that you're depending on the default maximum log event size configuration in
DefaultBatchFormatter
orArrayBatchFormatter
, or have defined your own limit when instantiating these classes, you should apply the following changes.// Before migration log = new LoggerConfiguration() // Changes are also applicable to Http and DurableHttpUsingTimeRolledBuffers .WriteTo.DurableHttpUsingFileSizeRolledBuffers( requestUri: "https://www.mylogs.com", batchFormatter: new ArrayBatchFormatter(ByteSize.MB)) .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.DurableHttpUsingFileSizeRolledBuffers( requestUri: "https://www.mylogs.com", logEventLimitBytes: ByteSize.MB, batchFormatter: new ArrayBatchFormatter()) .CreateLogger();
-
#171 [BREAKING CHANGE] Rename sink configuration argument
batchPostingLimit
tologEventsInBatchLimit
Migration guide
Given tha you're defining the maximum number of log events in a single batch, you should apply the following changes.
// Before migration log = new LoggerConfiguration() // Changes are also applicable to DurableHttpUsingFileSizeRolledBuffers // and DurableHttpUsingTimeRolledBuffers .WriteTo.Http( requestUri: "https://www.mylogs.com", batchPostingLimit: 100, .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.Http( requestUri: "https://www.mylogs.com", logEventsInBatchLimit: 100, .CreateLogger();
Given you are configuring the sink in application configuration you should apply the following changes.
// Before migration // Changes are also applicable to DurableHttpUsingFileSizeRolledBuffers // and DurableHttpUsingTimeRolledBuffers { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com", "batchPostingLimit": 100 } } ] } } // After migration { "Serilog": { "WriteTo": [ { "Name": "Http", "Args": { "requestUri": "https://www.mylogs.com", "logEventsInBatchLimit": 100 } } ] } }
-
[BREAKING CHANGE] Method
IHttpClient.Configure
on a custom HTTP client implementation is no longer called unless sink is provided an instance ofIConfiguration
-
#182 [BREAKING CHANGE] Extension method
DurableHttp
which was marked as deprecated in v5.2.0 -
#215 [BREAKING CHANGE] Remove support for .NET Standard 1.3, aligning with the cross-platform targeting library guidance
Migration guide
Given you are configuring the sink in code you should apply the following changes.
// Before migration log = new LoggerConfiguration() .WriteTo.DurableHttp(requestUri: "https://www.mylogs.com") .CreateLogger(); // After migration log = new LoggerConfiguration() .WriteTo.DurableHttpUsingTimeRolledBuffers(requestUri: "https://www.mylogs.com") .CreateLogger();
Given you are configuring the sink in application configuration you should apply the following changes.
// Before migration { "Serilog": { "WriteTo": [ { "Name": "DurableHttp", "Args": { "requestUri": "https://www.mylogs.com" } } ] } } // After migration { "Serilog": { "WriteTo": [ { "Name": "DurableHttpUsingTimeRolledBuffers", "Args": { "requestUri": "https://www.mylogs.com" } } ] } }
-
#196 [BREAKING CHANGE] Overloaded method
IBatchFormatter.Format(IEnumerable<LogEvent>, ITextFormatter, TextWriter)
has been removed in favour of keepingIBatchFormatter.Format(IEnumerable<string>, TextWriter output)
Migration guide
You'll have to migrate your code if you've implemented your own version of
IBatchFormatter
.// Before migration public class MyBatchFormatter : IBatchFormatter { public void Format(IEnumerable<LogEvent> logEvents, ITextFormatter formatter, TextWriter output) { // Your implementation accepting a sequence of log events } public void Format(IEnumerable<string> logEvents, TextWriter output) { // Your implementation accepting a sequence of serialized log events } } // After migration public class MyBatchFormatter : IBatchFormatter { public void Format(IEnumerable<string> logEvents, TextWriter output) { // Your implementation accepting a sequence of serialized log events } }
-
#178 [BREAKING CHANGE] Batch formatter
DefaultBatchFormatter
was removed whenArrayBatchFormatter
was promoted to default batch formatter.Migration guide
You'll have to migrate your code if you used
DefaultBatchFormatter
, either implicitly by not specifying a batch formatter, or explicitly by specifyingDefaultBatchFormatter
when configuring the sink.Given that you wish to continue using
DefaultBatchFormatter
as your batch formatter you should copy its implementation from the wiki into your own codebase.Given that you decide to migrate into using
ArrayBatchFormatter
instead ofDefaultBatchFormatter
, you should verify that your log server is capable of receiving the new JSON payload format.
- Durable buffer files are no longer created with an initial BOM
- #169 Rename buffer files to use the file extension
.txt
instead of.json
- #208 Transient dependency conflict for package Microsoft.Extensions.Configuration on ASP.NET Core 2.x (contribution by @AntonSmolkov)
- #220 - Text formatters
NamespacedTextFormatter
,NormalRenderedTextFormatter
andNormalTextFormatter
should write the timestamp in UTC
- Support for .NET Standard 2.1 (contributed by @augustoproiete)
- Add class
ByteSize
which helps specifying multipliers of the unit byte.
- #135 The type
IConfiguration
exists in bothMicrosoft.Extensions.Configuration.Abstractions
andSerilog.Sinks.Http
(discovered by @brian-pickens-web and contributed by @aleksaradz)
- #127 NuGet package does not show an icon
- Configure SourceLink to embed untracked sources
- Configure SourceLink to use deterministic builds when running on AppVeyor
- #49, #123 [BREAKING CHANGE] Improve support for configuring HTTP client when using Serilog.Settings.Configuration. See Custom HTTP client in wiki for more information. (discovered by @brunorsantos)
- #95 [BREAKING CHANGE] Support to specify
bufferFileShared
when creating a durable sink, thus allowing the buffer file to be shared by multiple processes (discovered by @esakkiraja-k)
- #97 Make sure the sink respects the exponential backoff, even after numerous unsuccessful attempts to send the log events to a log server (discovered by @markusbrueckner)
- Extension method
DurableHttpUsingFileSizeRolledBuffers
, creating a durable sink using buffer files with a file size based rolling behavior
- Extension method
DurableHttp
has been renamed toDurableHttpUsingTimeRolledBuffers
, providing clarification between the two durable sink types
- Support for .NET Framework 4.6.1 due to recommendations from the cross-platform targeting guidelines
- Support for .NET Standard 2.0 due to recommendations from the cross-platform targeting guidelines
- #54 Prevent durable HTTP sink from posting partially written log events
- #51 [BREAKING CHANGE] Support to specify
queueLimit
when creating a non-durable sink, limiting the number of events queued in memory waiting to be posted over the network.
- Event formatter called
NamespacedTextFormatter
suited for a micro-service architecture where log events are sent to the Elastic Stack. The event formatter reduces the risk of two services logging properties with identical names but with different types, which the Elastic Stack doesn't support.
- Support for .NET Standard 2.0 since the sink also has support for .NET Standard 1.3
- #32 Prevent durable HTTP sink from posting HTTP messages without any log events
- Support for .NET Core 2.0
- #22 Batch formatter
ArrayBatchFormatter
which is compatible with the Logstash HTTP input plugin configured to use the JSON codec
- Prevent posting HTTP messages without any log events
- #8 [BREAKING CHANGE] Support for Serilog.Settings.Configuration required changing the extension methods configuring a HTTP sink.
Options
andDurableOptions
no longer exist, and their properties are now optional parameters on the extension methods instead. - #11 Support for HTTP body configuration using
IBatchFormatter
andITextFormatter
. This enables full control of how messages are serialized before being sent over the network. (contribution by @kvpt) - #19 Support for specifying the maximum number of retained buffer files and their rotation period on the durable HTTP sink. (contribution by @rob-somerville)
- #11 Enum
FormattingType
has been replaces with public access to the formattersNormalRenderedTextFormatter
,NormalTextFormatter
,CompactRenderedTextFormatter
andCompactTextFormatter
. Removing the enum opens up the possibility to specify your own text formatter. (contribution by @kvpt)
- Package project URL
- Support for the formatting types:
FormattingType.NormalRendered
,FormattingType.Normal
,FormattingType.CompactRendered
andFormattingType.Compact
. The formatting type can be configured viaOptions
andDurableOptions
.
- #3 Support for configuring a sink to be durable using
Http(string, DurableOptions)
. A durable sink will persist log events on disk before sending them over the network, thus protecting against data loss after a system or process restart.
- [BREAKING CHANGE] The syntax for creating a non-durable sink has been changed from
Http(string)
toHttp(string, Options)
to accommodate for the syntax to create a durable sink. A non-durable sink will lose data after a system or process restart. - Improve compatibility by supporting .NET Standard 1.3
- #1 [BREAKING CHANGE] Sinks can be configured to use a custom implementation of
IHttpClient
(contribution by @lhaussknecht)
Initial version.