【C#】.net core 6.0 使用第三方日志插件Log4net,日志输出到控制台或者文本文档

本文主要是介绍【C#】.net core 6.0 使用第三方日志插件Log4net,日志输出到控制台或者文本文档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎来到《小5讲堂》
大家好,我是全栈小5。
这是《C#》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 背景
  • 插件简介
  • 插件安装
  • 配置文件
    • 日志类型
    • 文件详情
  • 日志设置
    • 命名空间
    • 实例化
    • 日志调用
  • 输出控制台
  • 输出文本文档
  • 相关文章

背景

最近在最一些并发方式的测试,发现自己之前封装的一个日志插件报错,
尽管在写日志时已经通过锁的方式进行了优化,但是依然无法解决并发时同一个文件同时访问情况,
会频繁出现报错提示xxx.txt文件正在被另一个进程访问而不无法操作。
基于这个原因,暂时没有想好很好的优化方案,从而考虑使用第三方优秀日志插件来解决并发情况。

插件简介

Log4net 是一个稳定且功能丰富的日志库,已经存在多年并且被广泛使用。
它支持多种输出目标和格式,可以满足各种日志记录需求。
Log4net 具有灵活的配置选项,允许你根据需要定制日志记录行为。

插件安装

在项目中添加对 Log4net 的引用。可以使用 NuGet 包管理器来安装 Log4net。
选择一个合适版本进行安装,博主这里选择最新版本安装。
在这里插入图片描述

配置文件

日志类型

在 log4net 中,日志类型一般分为以下几种,对应不同的日志级别:

1.DEBUG
最详细的日志级别,通常用于打印一些调试信息,仅在开发和调试阶段使用,生产环境中通常不会记录 DEBUG 级别的日志。

2.INFO
用于记录程序正常运行时的重要信息,比如服务启动、关键流程开始或结束等。对于用户而言,通常不需要关注 INFO 级别的日志,但这些日志对于开发人员来说非常重要。

3.WARN
表明潜在的问题,但不会影响系统正常运行,比如某个接口请求参数不合法,程序采取了默认值处理;或者磁盘空间不足,但系统仍然能够正常运行。WARN 级别的日志用于提示开发人员和运维人员需要注意的问题。

4.ERROR
用于记录错误事件,但不会导致程序终止。比如捕获到了一个异常,程序进行了相应的处理,不会导致程序崩溃。ERROR 级别的日志通常需要开发人员及时关注并处理。

5.FATAL
表示严重的错误事件,可能导致程序终止。比如未捕获的异常、数据库连接失败等致命错误。FATAL 级别的日志表示系统出现了严重的错误,需要立即处理。

文件详情

此配置文件内容,按日志级别创建文件,按时间年月日时来创建文件名,同一小时内超过10M文件大小则拆分文件保存。

<?xml version="1.0" encoding="utf-8" ?>
<log4net><!--定义日志级别--><root><level value="FATAL"/><level value="ERROR"/><level value="WARN"/><level value="INFO"/><level value="DEBUG"/><appender-ref ref="FATALAppender" /><appender-ref ref="ERRORAppender" /><appender-ref ref="WARNAppender" /><appender-ref ref="INFOAppender" /><appender-ref ref="DebugAppender" /></root><!--严重错误日志--><appender name="FATALAppender" type="log4net.Appender.RollingFileAppender"><file type="log4net.Util.PatternString" value="logs\Fatal\%date{yyyyMMddHH}.log" /><appendToFile value="true" /><rollingStyle value="Size" /><staticLogFileName value="false"/><maximumFileSize value="100KB"/><maxSizeRollBackups value="-1"/><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /></layout></appender><!--调试日志--><appender name="DebugAppender" type="log4net.Appender.RollingFileAppender"><file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" /><appendToFile value="true" /><rollingStyle value="Size" /><staticLogFileName value="false"/><maximumFileSize value="100KB"/><maxSizeRollBackups value="-1"/><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /></layout></appender>
</log4net>

通过使用不同级别的日志记录,开发人员和运维人员可以更好地了解系统的运行情况,及时发现潜在问题,并采取相应的措施进行处理。

日志设置

命名空间

using log4net;
using log4net.Config;
using System.Reflection;

实例化

// 日志插件
var logRepository = LogManager.GetRepository(Assembly.GetEntryAssembly());
XmlConfigurator.Configure(logRepository, new FileInfo(Path.Combine(AppContext.BaseDirectory, "log4net.config")));

日志调用

private static readonly ILog log = LogManager.GetLogger(typeof(SqlHelper));public void Test()
{    log.Fatal("Fatal message");log.Debug("Debug message");log.Info("Info message");log.Warn("Warn message");log.Error("Error message");
}

输出控制台

根据上面默认配置文件信息,日志信息输出到控制台里。
使用的类型是log4net.Appender.ConsoleAppender

<?xml version="1.0" encoding="utf-8" ?>
<log4net><appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date [%thread] %-5level %logger - %message%line" /></layout></appender><root><level value="DEBUG" /><appender-ref ref="ConsoleAppender" /></root>
</log4net>

在这里插入图片描述

输出文本文档

根据上面默认配置文件信息,日志信息输出到文本文档里。
使用的类型是log4net.Appender.Appender.RollingFileAppender

<?xml version="1.0" encoding="utf-8" ?>
<log4net><!--定义日志级别--><root><level value="DEBUG"/><appender-ref ref="DebugAppender" /></root><!--调试日志--><appender name="DebugAppender" type="log4net.Appender.RollingFileAppender"><file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" /><appendToFile value="true" /><rollingStyle value="Size" /><staticLogFileName value="false"/><maximumFileSize value="100KB"/><maxSizeRollBackups value="-1"/><lockingModel type="log4net.Appender.FileAppender+MinimalLock" /><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /></layout></appender>
</log4net>

在这里插入图片描述

相关文章

【C#】.net core 6.0 使用第三方日志插件Log4net,配置文件详细说明
【C#】使用代码实现龙年春晚扑克牌魔术(守岁共此时),代码实现篇
【C#】使用代码实现龙年春晚扑克牌魔术(守岁共此时),流程描述篇
【C#】约瑟夫原理举例2个代码实现
【C#】List泛型数据集如何循环移动,最后一位移动到第一位,以此类推
【C#】获取文本中的链接,通过正则表达式的方法获取以及优化兼容多种格式

温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

这篇关于【C#】.net core 6.0 使用第三方日志插件Log4net,日志输出到控制台或者文本文档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/804655

相关文章

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经