C# log4net 配置

C# log4net 配置

log4net由来

  1. log4net库是Apache log4j框架在Microsoft
    .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台、文件、数据库等)的工具。 [1]
  2. log4net是Apache软件基金会Apache Logging Services工程的一部分。Apache日志服务工程致力于为程序调试和审计提供跨语言的日志服务。
    建议写日志直接使用log4net ,解决了多并发的问题。

log4net 配置

  1. 首先下载一个log4net,在解决方案中引用类库文件。
  2. 添加一个XML文件,在XML文件中配置。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <!-- Level的级别,由高到低 -->
  <!-- None > Fatal > ERROR > WARN > DEBUG > INFO > ALL-->
  <!-- 解释:如果level是ERROR,则在cs文件里面调用log4net的info()方法,则不会写入到日志文件中-->
  <log4net>
    <!--错误日志类-->
    <logger name="logerror">
      <!--日志类的名字-->
      <level value="ALL" />
      <!--定义记录的日志级别-->
      <appender-ref ref="ErrorAppender" />
      <!--记录到哪个介质中去-->
    </logger>
    <!--信息日志类-->
    <logger name="loginfo">
      <level value="ALL" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <!--错误日志附加介质-->
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <!-- name属性指定其名称,type则是log4net.Appender命名空间的一个类的名称,意思是,指定使用哪种介质-->
      <param name="File" value="Log\\LogError\\" />
      <!--日志输出到exe程序这个相对目录下-->
      <param name="AppendToFile" value="true" />
      <!--输出的日志不会覆盖以前的信息-->
      <param name="MaxSizeRollBackups" value="100" />
      <!--备份文件的个数-->
      <param name="MaxFileSize" value="10240" />
      <!--当个日志文件的最大大小-->
      <param name="StaticLogFileName" value="false" />
      <!--是否使用静态文件名-->
      <param name="DatePattern" value="yyyy-MM-dd.log" />
      <!--日志文件名-->
      <param name="RollingStyle" value="Date" />
      <!--文件创建的方式,这里是以Date方式创建-->
      <!--错误日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n异常时间:%d [%t] %n异常级别:%-5p %n异常位置:[%thread] (%file:%line) %n消息描述:%message%n异常:%exception%n%n"  />
      </layout>
    </appender>
    <!--信息日志附加介质-->
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <!--设置日志存储路径-->
      <param name="File" value="Log\\LogInfo\\" />
      <!--是否追加到文件-->
      <param name="AppendToFile" value="true" />
      <param name="MaxFileSize" value="10240" />
      <!--最多产生的日志文件数,超过则只保留最新的n个。设定值value="-1"为不限文件数-->
      <param name="MaxSizeRollBackups" value="100" />
      <!--是否只写到一个文件中-->
      <param name="StaticLogFileName" value="false" />
      <!--这是按日期产生文件夹,并在文件名前也加上日期-->
      <param name="DatePattern" value="yyyy-MM-dd&quot;.log&quot;" />
      <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
      <param name="RollingStyle" value="Date" />
      <!--信息日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n日志时间:%d [%t] %n日志级别:%-5p %n消息描述:%c [%x] %n%m %n "  />
      </layout>
    </appender>
  </log4net>
</configuration>

log4net 在C# 中如何应用

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//log4net从配置文件中读取配置
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]
namespace WindowsService1.Tool
{

    public class LogHelper
    {
        private static readonly log4net.ILog logger = log4net.LogManager.GetLogger("LogInfo");//初始化log4net

        /// <summary>
        /// 写入正确的log
        /// </summary>
        /// <param name="log"></param>
        public static void WriteLog(string log)
        {
            logger.Info(log);
        }
        /// <summary>
        /// 报错时要写的log
        /// </summary>
        /// <param name="log"></param>
        public static void WriteError(string log)
        {
            logger.Error(log);
        }
        /// <summary>
        /// 预警时写的log
        /// </summary>
        /// <param name="log"></param>
        public static void WriteWarn(string log)
        {
            logger.Warn(log);
        }
        /// <summary>
        /// debug时写的log
        /// </summary>
        /// <param name="log"></param>
        public static void WriteDebug(string log)
        {
            logger.Debug(log);
        }
    }
}

注意事项

使用log4net 必须在管理员的权限下执行

C#中使用log4net进行日志记录,你需要进行以下配置步骤: 1. 添加log4net引用:首先,确保你的项目中已经添加了log4net的引用。你可以通过NuGet包管理器来添加log4net引用,或者手动下载log4net库并将其添加到项目中。 2. 创建log4net配置文件:在项目中创建一个名为log4net.config(或者任何你喜欢的名称)的文件,用来配置log4net。这个文件的格式是XML格式。 3. 配置log4net:打开log4net.config文件,并在其中配置你想要的日志记录器、附加器和布局。根据你的需求,你可以配置不同的日志记录级别、输出目标、日志文件路径等等。 以下是一个简单的log4net配置示例: ```xml <?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%newline" /> </layout> </appender> <root> <level value="DEBUG" /> <appender-ref ref="ConsoleAppender" /> </root> </log4net> ``` 在这个示例中,我们配置了一个名为ConsoleAppender的附加器,用于将日志输出到控制台。我们还配置了一个根日志记录器,并将日志级别设置为DEBUG,并将ConsoleAppender附加到根日志记录器上。 4. 加载log4net配置:在你的应用程序的入口点(例如Main方法)中,添加以下代码来加载log4net配置: ```csharp using log4net; using log4net.Config; class Program { private static readonly ILog log = LogManager.GetLogger(typeof(Program)); static void Main(string[] args) { XmlConfigurator.Configure(new FileInfo("log4net.config")); log.Debug("Debug message"); log.Info("Info message"); log.Warn("Warn message"); log.Error("Error message"); log.Fatal("Fatal message"); } } ``` 在这个示例中,我们首先引入log4netlog4net.Config命名空间。然后,我们使用ILog接口创建一个日志记录器,并在Main方法中使用该日志记录器输出不同级别的日志消息。 注意:在加载log4net配置之前,确保log4net.config文件与应用程序的可执行文件在同一目录下,或者你可以指定配置文件的完整路径。 这就是使用log4net进行日志记录的基本配置步骤。你可以根据自己的需求进行进一步的配置和定制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值