开源测试_log4net

测试可用

代码

csharp 复制代码
using log4net;
string logDirectory = "D:/log";
if (!Directory.Exists(logDirectory))
{
    Directory.CreateDirectory(logDirectory);
}

//初始化 log4net  
log4net.Config.XmlConfigurator.Configure(new FileInfo("log4net.config"));

ILog errorLogger = LogManager.GetLogger("logerror");
ILog warningLogger = LogManager.GetLogger("logoperate");
ILog infoLogger = LogManager.GetLogger("loginfo");

//记录日志示例  
errorLogger.Error("This is an error message.");
warningLogger.Warn("This is a warning message.");
infoLogger.Info("This is an info message.");

try {
    int i = 0;
    var e = 1 / i;
}
catch(Exception e) {
    errorLogger.Error("error", e);
}

config

csharp 复制代码
<configuration>
  <log4net>
    <!--错误日志类-->
    <logger name="logerror">
      <!--定义记录的日志级别-->
      <level value="ALL" />
      <appender-ref ref="ErrorAppender" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <!--运行信息日志类-->
    <logger name="loginfo">
      <level value="ALL" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <!--操作日志类-->
    <logger name="logoperate">
      <level value="ALL" />
      <appender-ref ref="OperateAppender" />
      <appender-ref ref="InfoAppender" />
    </logger>

    <!--错误日志附加介质-->
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <!-- name属性指定其名称,type则是log4net.Appender命名空间的一个类的名称,意思是,指定使用哪种介质-->
      <param name="File" value="D:\\Log\\Error" />
      <param name="AppendToFile" value="true" />
      <param name="MaximumFileSize" value="10MB" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/>
      <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <param name="RollingStyle" value="Date" />
      <!--信息日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n %loggername" />-->
        <param name="ConversionPattern" value="%date [%t] - %m%n" />
      </layout>
    </appender>

    <!--信息日志附加介质-->
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="D:\\Log\\Info" />
      <param name="AppendToFile" value="true" />
      <param name="MaximumFileSize" value="10MB" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/>
      <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <param name="RollingStyle" value="Date" />
      <!--信息日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n %loggername" />-->
        <param name="ConversionPattern" value="%d [%t][%-1level] - %m%n" />
      </layout>
    </appender>


    <!--警告日志附加介质-->
    <appender name="OperateAppender" type="log4net.Appender.RollingFileAppender">
      <!-- name属性指定其名称,type则是log4net.Appender命名空间的一个类的名称,意思是,指定使用哪种介质-->
      <param name="File" value="D:\\Log\\Operate" />
      <param name="AppendToFile" value="true" />
      <param name="MaximumFileSize" value="10MB" />
      <!-- 保存天数-->
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/>
      <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <param name="RollingStyle" value="Date" />
      <!--信息日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n %loggername" />-->
        <param name="ConversionPattern" value="%d [%t] - %m%n" />
      </layout>
    </appender>

    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%d [%t]%-5p %c- %m%n" />
      </layout>
    </appender>
  </log4net>
</configuration>
相关推荐
百锦再35 分钟前
.NET 的 WebApi 项目必要可配置项都有哪些?
java·开发语言·c#·.net·core·net
hqwest12 小时前
C#WPF实战出真汁06--【系统设置】--餐桌类型设置
c#·.net·wpf·布局·分页·命令·viewmodel
做一位快乐的码农15 小时前
基于.net、C#、asp.net、vs的保护大自然网站的设计与实现
c#·asp.net·.net
YF云飞19 小时前
.NET 在鸿蒙系统(HarmonyOS Next)上的适配探索与实践
华为·.net·harmonyos
小码编匠20 小时前
C# Bitmap 类在工控实时图像处理中的高效应用与避坑
后端·c#·.net
咕白m6252 天前
C# 将 Excel 转为 CSV 的高效解决方案
.net
不知名搬运工2 天前
18 ABP Framework 模块管理
.net
追逐时光者2 天前
精选 5 款 .NET 开源、功能强大的工作流系统,告别重复造轮子!
后端·.net
专注VB编程开发20年3 天前
c#,vb.net全局多线程锁,可以在任意模块或类中使用,但尽量用多个锁提高效率
java·前端·数据库·c#·.net
岩屿3 天前
.NET 应用程序 Linux下守护进程脚本编写
linux·运维·服务器·c#·.net