首页 > 其他分享 >.net下优秀的日志框架Serilog,你用上了吗?强烈推荐

.net下优秀的日志框架Serilog,你用上了吗?强烈推荐

时间:2023-12-06 09:00:26浏览次数:38  
标签:插件 记录 Serilog WriteTo Elasticsearch net 日志

 

在 .NET 开发中,Serilog 是一款广受欢迎的日志库,它提供了强大的日志记录功能,具有丰富的特性和高度的可扩展性。Serilog 的优秀之处包括:

  1. 可扩展性: Serilog 可以轻松扩展以满足不同的日志记录需求,例如日志存储、格式化和过滤。它支持各种插件和自定义扩展,让你可以根据项目的具体要求定制日志记录功能。
  2. 结构化日志: Serilog 支持结构化日志,允许你以键值对的形式记录信息,这使得日志数据更容易分析和查询。这对于在日志中存储复杂的数据非常有用。
  3. 异步日志记录: Serilog 可以异步记录日志,这有助于提高应用程序的性能,减少因日志记录而引起的延迟。
  4. 多种输出目标: Serilog 支持多种输出目标,包括控制台、文件、数据库、第三方日志服务等。你可以将日志记录到不同的目标,以满足不同的需求。
  5. 过滤器和级别控制: Serilog 允许你使用过滤器来选择哪些日志消息应该被记录,以及记录的级别。这有助于减少日志的噪音,并仅记录关键信息。
  6. 内建支持: Serilog 支持各种 .NET 技术栈,包括 ASP.NET Core、Entity Framework、Xamarin 和其他常见的 .NET 应用程序框架。

在本文中,我们将详细介绍 Serilog 的各种优秀之处,并提供示例代码来演示其使用方法,包括高级应用和持久化方案。

Serilog 的基本使用

1. 安装 Serilog

首先,你需要在项目中安装 Serilog 包,可以使用 NuGet 包管理器或 .NET CLI 进行安装。

dotnet add package Serilog
dotnet add package Serilog.Sinks.Console

上述命令将安装 Serilog 的核心包和一个输出到控制台的插件。

2. 配置 Serilog

在应用程序中配置 Serilog,你可以在 Program.cs 文件中进行配置。以下是一个简单的配置示例,将日志记录到控制台。

using Serilog;
using Serilog.Sinks.Console;

public class Program
{
    public static void Main(string[] args)
    {
        Log.Logger = new LoggerConfiguration()
            .WriteTo.Console()
            .CreateLogger();

        // 启动应用程序
        CreateWebHostBuilder(args).Build().Run();
    }
    
    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .UseSerilog() // 将 Serilog 集成到 ASP.NET Core
            .UseStartup<Startup>();
}

3. 记录日志

现在,你可以在应用程序中记录日志。以下是一个简单的示例,在控制器中记录日志:

using Microsoft.AspNetCore.Mvc;
using Serilog;

public class MyController : ControllerBase
{
    public IActionResult Index()
    {
        Log.Information("访问了首页");
        return View();
    }
}

上述代码使用 Log.Information 方法记录信息级别的日志消息。

4. 结构化日志记录

Serilog 支持结构化日志记录,这允许你以键值对的形式记录信息。以下是一个示例:

Log.Information("用户登录 {@User}", new { Username = "john", UserId = 123 });

这种结构化的日志记录对于存储和查询复杂的数据非常有用。

Serilog 高级应用

1. 自定义输出目标

Serilog 允许你将日志记录到不同的输出目标,如文件、数据库或第三方日志服务。以下是一个示例,将日志记录到文件中。

首先,安装 Serilog 的文件输出插件:

dotnet add package Serilog.Sinks.File

然后,配置 Serilog 以将日志记录到文件:

Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .WriteTo.File("log.txt") // 将日志记录到文件
    .CreateLogger();

2. 异步日志记录

使用 Serilog 异步记录日志可以提高性能,特别是在高负载应用程序中。以下是一个示例:

Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .WriteTo.Async(a => a.File("log.txt")) // 异步将日志记录到文件
    .CreateLogger();

3. 过滤器和级别控制

Serilog 允许你使用过滤器来选择哪些日志消息应该被记录,以及记录的级别。以下是一个示例,只记录信息级别的日志消息:

Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .MinimumLevel.Information() // 只记录信息级别的日志
    .CreateLogger();

你还可以使用过滤器来更精确地控制哪些消息应该被记录。

Serilog 持久化方案

Serilog 支持各种持久化方案,允许你将日志数据存储在不同的地方,如文件、数据库或第三方日志服务。以下是一些常见的持久化方案。

1. 文件持久化

你可以使用 Serilog 的文件插件将日志记录到文件中,如前面所示。这是一个简单的持久化方案,适用于小型应用程序。

2. 数据库持久化

如果你希

望将日志数据存储在数据库中,你可以使用 Serilog 的数据库插件,如 Serilog.Sinks.MSSqlServer 或 Serilog.Sinks.PostgreSQL。

首先,安装适当的数据库插件:

dotnet add package Serilog.Sinks.MSSqlServer

然后,配置 Serilog 以将日志记录到数据库:

Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .WriteTo.MSSqlServer("connectionString", "tableName") // 将日志记录到数据库
    .CreateLogger();

3. Elasticsearch 持久化

如果你使用 Elasticsearch 作为日志存储后端,你可以使用
Serilog.Sinks.Elasticsearch 插件将日志记录到 Elasticsearch。

首先,安装 Elasticsearch 插件:

dotnet add package Serilog.Sinks.Elasticsearch

然后,配置 Serilog 以将日志记录到 Elasticsearch:

Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .WriteTo.Elasticsearch(new ElasticsearchSinkOptions(new Uri("http://localhost:9200"))) // 将日志记录到 Elasticsearch
    .CreateLogger();

这个插件将日志数据导入 Elasticsearch,你可以使用 Elasticsearch 强大的搜索和分析功能来查询日志数据。

Serilog 是一个功能丰富、可扩展且易于使用的.NET日志库。它支持多种日志记录场景,包括控制台、文件、数据库和第三方日志服务,具有强大的结构化日志记录功能,使日志数据更容易管理和分析。在本文中,我们详细介绍了 Serilog 的优秀之处和使用方法,包括基础使用、高级应用和不同的持久化方案。希望这个指南有助于你更好地理解和利用 Serilog 来提高应用程序的日志记录质量和性能。

 

标签:插件,记录,Serilog,WriteTo,Elasticsearch,net,日志
From: https://www.cnblogs.com/hanbing81868164/p/17878704.html

相关文章

  • pointnet cfd训练
    1#####Point-clouddeeplearningforpredictionoffluidflowfieldsonirregulargeometries(supervisedlearning)#####9importos#提供与操作系统交互的功能,例如文件和目录操作。10importlinecache#提供从文件中读取特定行的方法。11importmath......
  • .NET(C#) 对象判等
    值类型变量判断就是比较值是否相等,而引用类型的对象判断是否相等,一般是判断指定的对象是否是相同的实例。也就是比较对象引用的值,但是也有可能有特殊情况,虽然不是相同的实例,但在业务上可能是相等的。就要结合具体的情况判断是否相等了。一般判断对象是否相等的方法有4种。......
  • .NET微信网页开发相关文章教程
    前言今天我们主要总结一下.NET微信网页开发的相关文章教程。微信网页开发详细文档可以看微信官方文档:https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_webpage_authorization.html 全面的.NET微信网页开发之JS-SDK使用步骤、配置信息和接口请求签名......
  • .NET Core 开发的支付SDK集 - paylink
    一套基于.NETCore开发的支付SDK集-paylink 前言在我们的日常工作开发中对接一些第三方支付是比较常见的,如最常见的就是支付宝、微信支付的对接。今天给大家推荐一个基于.NETCore开发的支付SDK集:paylink,它极大简化了API调用及通知的处理流程从而大大提供我们的工作生......
  • Linux监测工具 - NetData
    安装yuminstall-ynetdata.x86_64配置vi/etc/netdata/netdata.conf##修改默认端口,默认为:19999defaultport=19999##修改bindto=localhost为bindto=0.0.0.0bindto=0.0.0.0##重启systemctlrestartnetdata访问地址http://localhost:19999/netda......
  • ML.NET 3.0 增强了深度学习和数据处理能力
    .NET团队在2023.11.28在博客上正式发布了ML.NET3.0::https://devblogs.microsoft.com/dotnet/announcing-ml-net-3-0/[1],强调了两个主要的兴趣点,即深度学习和数据处理,使开发人员能够完全在.NET生态系统中创建注入AI的应用程序。开源ML.NET框架[2]的主要卖点,旨在帮助开发人......
  • ADO.NET组成
    SqlConnection(数据库连接器)SqlCommand(数据库命名对象)SqlCommandBuilder(生存SQL命令)SqlDataReader(数据读取器)SqlDataAdapter(数据适配器填充DataSet)SqlParameter(为存储过程定义参数)SqlTransaction(数据库事物) Connection连接对象Connection对象也称为数据库连接对象,Connec......
  • 从 Elasticsearch 到 SelectDB,观测云实现日志存储与分析的 10 倍性价比提升
    导读:在云计算逐渐成熟的当下,越来越多的企业开始将业务迁移到云端,传统的监控和故障排查方法已经无法满足企业的需求。观测云可以实现对云、云原生、应用及业务的统一监测,提供整体数据的分析、洞察、可视化、自动化、监测告警、智能巡查、安全巡查等服务。本文将分享SelectDB如何助......
  • 不要用第三方日志包了Microsoft.Extensions.Logging功能就很强大
    在.NET中,Microsoft.Extensions.Logging是一个广泛使用的日志库,用于记录应用程序的日志信息。它提供了丰富的功能和灵活性,使开发人员能够轻松地记录各种类型的日志,并将其输出到不同的目标,包括日志文件。本文将详细介绍Microsoft.Extensions.Logging的各种基础功能以及如何按天生成......
  • 企业网络安全守护者:EventLog Analyzer日志审计系统
    在当今数字时代,企业网络不仅仅是业务运营的核心,也成为各种潜在威胁的目标。为了保障企业的网络安全,日志审计系统成为了不可或缺的一环。其中,ManageEngine的EventLogAnalyzer作为一款强大而全面的日志管理与审计解决方案,为企业提供了保护网络的关键工具。日志审计1.日志审计的重要......