背景
最近在最一些并发方式的测试,发现自己之前封装的一个日志插件报错,尽管在写日志时已经通过锁的方式进行了优化,但是依然无法解决并发时同一个文件同时访问情况,会频繁出现报错提示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#使用log4net实现将日志输出到控制台或者文本文档的文章就介绍到这了,更多相关c# log4net日志输出内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论