Serilog.Sinks.MongoDB 7.0.0

dotnet add package Serilog.Sinks.MongoDB --version 7.0.0                
NuGet\Install-Package Serilog.Sinks.MongoDB -Version 7.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Serilog.Sinks.MongoDB" Version="7.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Serilog.Sinks.MongoDB --version 7.0.0                
#r "nuget: Serilog.Sinks.MongoDB, 7.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Serilog.Sinks.MongoDB as a Cake Addin
#addin nuget:?package=Serilog.Sinks.MongoDB&version=7.0.0

// Install Serilog.Sinks.MongoDB as a Cake Tool
#tool nuget:?package=Serilog.Sinks.MongoDB&version=7.0.0                

mongo icon Serilog.Sinks.MongoDB

NuGet version Downloads Build status

A Serilog sink that writes events as documents to MongoDB.

Package - Serilog.Sinks.MongoDB Platforms - .NET 4.7.2, .NET 6.0, .NET Standard 2.1

Whats New

New in v7.x
  • Upgrade MongoDB.Driver to v3.0 - .NET Standard 2.0 support has been removed.
New in v6.x
  • Upgrade MongoDB.Driver to v2.28.0 (Thanks to Memoyu)
  • Add trace context to LogEntry (Thanks to fernandovmp)
New in v5.x
  • Output structured MongoDB Bson logs by switching to .MongoDBBson() extensions. Existing .MongoDB() extensions will continue to work converting logs to Json and then to Bson.
  • Rolling Log Collection Naming (Thanks to Revazashvili for the PR!). MongoDBBson sink only.
  • Expire TTL support. MongoDBBson sink only.

Installation

Install the sink via NuGet Package Manager Console:

Install-Package Serilog.Sinks.MongoDB

or via the .NET CLI:

dotnet add package Serilog.Sinks.MongoDB

Usage Examples

In the examples below, the sink is writing to the database logs with structured Bson. The default collection name is log, but a custom collection can be supplied with the optional CollectionName parameter. The database and collection will be created if they do not exist.

Basic:

using Serilog;

// use BSON structured logs
var log = new LoggerConfiguration()
    .WriteTo.MongoDBBson("mongodb://mymongodb/logs")
    .CreateLogger();

log.Information("This is a test log message");

Capped Collection:

// capped collection using BSON structured logs
var log = new LoggerConfiguration()
    .WriteTo.MongoDBBson("mongodb://mymongodb/logs", cfg =>
    {
        // optional configuration options:
        cfg.SetCollectionName("log");
        cfg.SetBatchPeriod(TimeSpan.FromSeconds(1));

        // create capped collection that is max 100mb
        cfg.SetCreateCappedCollection(100);
    })
    .CreateLogger();

Custom Mongodb Settings:

// create sink instance with custom mongodb settings.
var log = new LoggerConfiguration()
	.WriteTo.MongoDBBson(cfg =>
    {
		// custom MongoDb configuration
		var mongoDbSettings = new MongoClientSettings
		{
			UseTls = true,			
			AllowInsecureTls = true,
			Credential = MongoCredential.CreateCredential("databaseName", "username", "password"),
			Server = new MongoServerAddress("127.0.0.1")
		};

		var mongoDbInstance = new MongoClient(mongoDbSettings).GetDatabase("serilog");
		
		// sink will use the IMongoDatabase instance provided
		cfg.SetMongoDatabase(mongoDbInstance);
		cfg.SetRollingInternal(RollingInterval.Month);
    })
	.CreateLogger();

JSON (Microsoft.Extensions.Configuration)

Keys and values are not case-sensitive. This is an example of configuring the MongoDB sink arguments from Appsettings.json:

{
  "Serilog": {
    "MinimumLevel": {
      "Default": "Information",
      "Override": {
        "Microsoft": "Error",
        "System": "Warning"
      }
    },
    "WriteTo": [
      { 
      	"Name": "MongoDBBson", 
        "Args": { 
            "databaseUrl": "mongodb://username:password@ip:port/dbName?authSource=admin",
            "collectionName": "logs",
            "cappedMaxSizeMb": "1024",
            "cappedMaxDocuments": "50000",
            "rollingInterval": "Month"
        }
      } 
    ]
  }
}

Icon

MongoDB icon by Icons8

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
.NET Framework net472 is compatible.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (47)

Showing the top 5 NuGet packages that depend on Serilog.Sinks.MongoDB:

Package Downloads
TianCheng.Model

实体对象基类,及其常用操作。 常用操作包括:对象转换、序列化、日志、常用异常处理、依赖注入。

RG3.PF.Web.StartUsed

1、【核心业务使用包RG3.PF.Web.StartUsed】(可配置化,标准化,灵活配置,集成百度、腾讯、阿里、短信通等巨头接口,可脱离开发环境,集成nodejs中间件、统一认证中心) 2、以Rg3.开头且类继承 IService 或 IRepository的在Starup里面不用注入,案例如下 3、public class ListRepository : IRepository 4、public class ListService : IService 5、使用请到github获取 RG3.PF.WebApp.Host 6、Quartz集成redis订阅、Quartz 7、修复多引用CLDC 8、接入微信公众号wxconfig 9、Prometheus+Grafana https://doc.rg1008.com/docs/rg_pass_log/rg_pass_log-1dpcuns9s6r8c 10、Headers添加VerifyApiValue 用于验证 11、添加时间戳 Convert.ToInt64(DateTimePFUtil.ToTimestampSecond(this.Expires)); 12、版本记录:https://doc.rg1008.com/docs/rg_pass_log/rg_pass_log-1dpubsabl25v4 13、 20240815 升级到.netcore sdk 8.0

Basic.Logging.Serilog

Package Description

Atlas.Framework.Web

Package Description

uBeac.Logging.MongoDB

Easily implement logging with MongoDB in your .NET projects!

GitHub repositories (3)

Showing the top 3 popular GitHub repositories that depend on Serilog.Sinks.MongoDB:

Repository Stars
DevArchitecture/DevArchitecture
DevArchitecture Backend Project
serilog-contrib/serilog-ui
Simple Serilog log viewer UI for several sinks.
keremvaris/Sennedjem
Sennedjem CQRS (Command Query Responsibility Segregation) yaklaşımını benimseyen ve SOLID prensiplerini ve Clean Architecture yöntemlerini odaklayan bir yazılım geliştirme alt yapısıdır. RabbitMq, ElasticSearch vb araçlara entegre olmak konusunda çok yeteneklidir.
Version Downloads Last updated
7.0.0 25,972 11/5/2024
6.0.0 43,231 9/20/2024
5.4.1 226,533 2/18/2024
5.3.1 896,239 9/28/2022
5.2.2 6,519 9/26/2022
5.2.1 30,443 9/3/2022
5.2.1-tags-v5-2-0-0000 299 9/3/2022
5.2.0 767 9/3/2022
5.1.5 283,284 4/24/2022
5.1.2 162,472 1/19/2022
5.1.2-dev-00124 315 3/12/2022
5.1.2-dev-00123 548 1/19/2022
5.1.2-dev-00121 523 1/19/2022
5.1.1 246,599 9/25/2021
5.1.1-dev-00120 565 1/19/2022
5.1.1-dev-00119 511 1/19/2022
5.1.1-dev-00118 546 1/19/2022
5.1.1-dev-00116 372 9/25/2021
5.1.0-dev-00114 393 9/25/2021
5.0.0 77,716 9/2/2021
5.0.0-dev-00112 442 9/24/2021
5.0.0-dev-00111 468 9/12/2021
5.0.0-dev-00110 438 9/12/2021
5.0.0-dev-00109 403 9/2/2021
5.0.0-dev-00107 387 9/2/2021
5.0.0-dev-00105 685 8/1/2021
5.0.0-dev-00104 1,884 5/8/2021
5.0.0-dev-00103 456 5/7/2021
5.0.0-dev-00100 20,992 5/6/2021
5.0.0-dev-00099 454 5/6/2021
5.0.0-dev-00098 433 5/6/2021
5.0.0-dev-00097 813 5/6/2021
4.1.0 386,434 5/6/2021
4.1.0-dev-00096 451 5/6/2021
4.1.0-dev-00094 426 5/6/2021
4.1.0-dev-00084 10,444 10/21/2020
4.1.0-dev-00069 16,711 1/29/2019
4.0.0 1,594,648 11/9/2018
4.0.0-dev-00068 542 1/29/2019
4.0.0-dev-00064 630 11/9/2018
4.0.0-dev-00062 7,197 2/15/2018
4.0.0-dev-00060 1,011 11/30/2017
3.1.1-dev-00059 797 11/30/2017
3.1.0 498,299 11/1/2016
3.1.0-dev-00049 976 10/30/2016
3.1.0-dev-00046 1,427 10/7/2016
3.1.0-dev-00044 857 10/7/2016
3.1.0-dev-00042 856 10/5/2016
3.1.0-dev-00037 905 10/5/2016
3.1.0-dev-00035 890 9/9/2016
3.1.0-dev-00033 848 9/8/2016
3.0.0 2,787 8/9/2016
3.0.0-dev-00030 867 8/9/2016
3.0.0-dev-00029 839 8/9/2016
3.0.0-beta-24 1,264 4/26/2016
2.0.19 12,745 2/16/2016
2.0.18 1,167 2/16/2016
2.0.14 22,675 1/26/2016
2.0.13 4,191 7/26/2015
2.0.11 2,085 4/18/2015
2.0.8-pre 973 4/2/2015
2.0.7-pre 927 3/26/2015
2.0.6-pre 917 3/16/2015
2.0.3-pre 929 3/10/2015
2.0.1-pre 935 2/1/2015
2.0.0-beta-27 837 5/6/2016
1.4.139 1,891 1/23/2015
1.4.118 1,176 1/13/2015
1.4.113 1,298 1/6/2015
1.4.102 1,660 12/21/2014
1.4.99 1,567 12/18/2014
1.4.97 1,420 12/18/2014
1.4.76 1,506 12/8/2014
1.4.39 1,385 11/26/2014
1.4.34 1,340 11/24/2014
1.4.28 1,396 11/24/2014
1.4.27 1,413 11/23/2014
1.4.23 1,519 11/21/2014
1.4.21 1,408 11/21/2014
1.4.18 1,484 11/18/2014
1.4.15 2,446 11/4/2014
1.4.14 1,341 10/23/2014
1.4.13 1,215 10/23/2014
1.4.12 1,308 10/12/2014
1.4.11 1,252 10/8/2014
1.4.10 1,268 9/26/2014
1.4.9 1,348 9/17/2014
1.4.8 1,272 9/11/2014
1.4.7 1,308 9/1/2014
1.4.6 1,219 8/31/2014
1.4.5 1,382 8/27/2014
1.4.4 1,257 8/27/2014
1.4.3 1,358 8/25/2014
1.4.2 1,277 8/23/2014
1.4.1 1,254 8/23/2014
1.3.43 1,516 8/4/2014
1.3.42 1,286 7/30/2014
1.3.41 1,264 7/28/2014
1.3.40 1,199 7/26/2014
1.3.39 1,224 7/25/2014
1.3.36 1,234 7/20/2014
1.3.35 1,220 7/17/2014
1.3.34 1,900 7/6/2014
1.3.33 1,225 6/30/2014
1.3.30 1,283 6/19/2014
1.3.29 1,277 6/19/2014
1.3.28 1,219 6/19/2014
1.3.27 1,257 6/18/2014
1.3.25 1,290 6/9/2014
1.3.24 1,334 5/21/2014
1.3.23 1,239 5/20/2014
1.3.20 1,283 5/18/2014
1.3.19 1,223 5/17/2014
1.3.18 1,201 5/17/2014
1.3.17 1,207 5/17/2014
1.3.16 1,234 5/17/2014
1.3.15 1,225 5/16/2014
1.3.14 1,330 5/16/2014
1.3.13 1,224 5/16/2014
1.3.12 1,237 5/14/2014
1.3.7 1,253 5/11/2014
1.3.6 1,257 5/9/2014
1.3.5 1,244 5/6/2014
1.3.4 1,358 5/4/2014
1.3.3 1,439 4/28/2014
1.3.1 1,269 4/26/2014
1.2.53 1,291 4/26/2014
1.2.52 1,520 4/24/2014
1.2.51 1,449 4/18/2014
1.2.50 1,392 4/18/2014
1.2.49 1,384 4/17/2014
1.2.48 1,365 4/14/2014
1.2.47 1,473 4/14/2014
1.2.45 1,514 4/13/2014
1.2.44 1,418 4/9/2014
1.2.41 1,354 4/7/2014
1.2.40 1,342 4/7/2014
1.2.39 1,309 3/29/2014
1.2.37 1,337 3/29/2014
1.2.29 1,353 3/16/2014
1.2.26 1,265 3/12/2014
1.2.25 1,310 2/20/2014
0.9.9 1,426 11/23/2013
0.9.1 1,403 8/24/2013
0.8.5 1,427 7/22/2013
0.8.1 1,469 7/9/2013
0.7.2 1,477 7/6/2013
0.6.1 1,423 6/13/2013
0.5.2 1,375 5/27/2013
0.5.1 1,375 5/26/2013
0.4.3 1,382 5/25/2013
0.3.2 1,341 5/19/2013
0.3.1 1,320 5/19/2013
0.2.10 1,369 5/13/2013
0.2.9 1,305 5/10/2013
0.2.7 1,283 5/8/2013
0.2.6 1,362 5/8/2013
0.2.5 1,339 5/7/2013
0.2.1 1,379 4/8/2013
0.1.18 1,387 4/6/2013
0.1.17 1,328 4/4/2013
0.1.16 1,356 4/3/2013
0.1.12 1,382 4/1/2013
0.1.11 2,605 3/30/2013

v7.0 - Upgraded to MongoDB.Driver to version 3.0 fixing incompatibilities.