【个人博客搭建】(9)使用日志

net自带日志与Serilog。

1、比较。net 8 webapi使用自带的日志功能与Serilog日志的异同,性能上有多少差距

在.NET 8 WebAPI中,使用自带的日志功能与使用Serilog日志框架存在一些异同。性能上的差距取决于具体的使用场景和配置,但通常Serilog提供了更多的灵活性和扩展性。以下是它们之间的比较:

  • 相同点
  1. 依赖注入 :Serilog和.NET内置的日志功能都支持通过依赖注入将ILogger<T>接口注入到类中,以便在应用程序中使用。
  2. 日志级别:两者都支持不同的日志级别,如调试、信息、警告、错误和临界,允许开发者根据需要记录不同级别的日志信息。
  3. 日志格式:Serilog和内置日志功能都允许自定义日志消息的格式,以满足特定的日志记录需求。
  • 不同点
  1. 扩展性和灵活性:Serilog提供了更多的扩展性和灵活性,例如可以通过编写自定义接收器来将日志发送到各种目标,包括文件、数据库、云服务等。而内置日志功能虽然也可以将日志写入文件,但在目标选择和定制方面不如Serilog丰富。
  2. 静态Log类 :Serilog提供了一个静态的Log类,这在某种程度上违反了依赖反转原则。但是,Serilog可以轻松地与Microsoft的内置日志接口集成,这样既可以利用Serilog的功能,又能保持依赖注入的优点。
  3. 性能:性能上的差异取决于具体的配置和使用情况。Serilog由于其丰富的功能和灵活性,可能会有一定的性能开销,但这通常不会成为问题,除非在极端的性能敏感场景中。在大多数常规应用中,性能差异可以忽略不计。

总结来说,Serilog提供了更多的功能和灵活性,尤其是在日志的存储和分析方面。如果需要高级的日志管理功能,Serilog可能是更好的选择。然而,如果只需要基本的日志记录功能,并且希望减少外部依赖,那么.NET内置的日志功能可能就足够了。性能方面,两者在常规应用中的差异通常不大,选择时应更多地考虑功能需求和项目的具体情况。

2、最简单方式。测试自带:

cs 复制代码
/// <summary>
/// 测试连接1
/// 异常
/// </summary>
/// <param name="t">字符串</param>
/// <returns></returns>
[HttpGet]
[ApiVersionCustomRoute(SwaggerDocSettings.ApiVersions.v1)]
public string Test(string t)
{
    int i = 0;
    try
    {

        i = int.Parse(t);
    }
    catch (Exception ex)
    {
        _logger.LogError("Test接口异常:" + ex.Message.ToString());
        return "报错,不可转int类型";
    }
    return "【Test】OK.输入的是:" + i.ToString();
}

2.1、效果:

相关推荐
csdn_aspnet10 分钟前
ASP.NET Core 中的多租户 SaaS 应用程序
.netcore·saas
★YUI★2 小时前
学习游戏制作记录(玩家掉落系统,删除物品功能和独特物品)8.17
java·学习·游戏·unity·c#
谷宇.2 小时前
【Unity3D实例-功能-拔枪】角色拔枪(二)分割上身和下身
游戏·unity·c#·游戏程序·unity3d·游戏开发·游戏编程
LZQqqqqo2 小时前
C# 中 ArrayList动态数组、List<T>列表与 Dictionary<T Key, T Value>字典的深度对比
windows·c#·list
Dm_dotnet5 小时前
Stylet启动机制详解:从Bootstrap到View显示
c#
三千道应用题7 小时前
WPF&C#超市管理系统(6)订单详情、顾客注册、商品销售排行查询和库存提示、LiveChat报表
开发语言·c#·wpf
唐青枫11 小时前
别滥用 Task.Run:C# 异步并发实操指南
c#·.net
我好喜欢你~18 小时前
C#---StopWatch类
开发语言·c#
一阵没来由的风1 天前
拒绝造轮子(C#篇)ZLG CAN卡驱动封装应用
c#·can·封装·zlg·基础封装·轮子
一枚小小程序员哈1 天前
基于微信小程序的家教服务平台的设计与实现/基于asp.net/c#的家教服务平台/基于asp.net/c#的家教管理系统
后端·c#·asp.net