log4net五步搞定法!(VS2019——三种分割方法)

Step1、引用log4net,通过NuGet下载,输入log,查询后如下图,安装Apache log4net,这里以VS2019为例;
工具-》nuget包管理器-》管理解决方案的nuget程序包-》浏览-》输入“log”回车-》-》点击"log4net"-》选择右边我们要添加log4net的项目-》选择版本-》安装即可,安装完成后项目会自动引用log4net。
在这里插入图片描述
Step2、在AssemblyInfo.cs代码末尾加上以上代码:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", ConfigFileExtension = "config", Watch = true)]

这里要注意ConfigFile其实是一个相对路径,并且指的是Debug路径下,我们也可以在Debug文件夹下新建一个文件夹比如AppConfig(新建文件有时候会有问题,在不同的电脑上会出现不同的情况,建议直接拷贝现有的config文件log4net.config文件下载)),然后将"log4net.config"放置到Debug文件夹下,那么我们这里的ConfigFile="AppConfig\log4net. config"或者ConfigFile="AppConfig/log4net. config"即可。

Step3、在程序运行目录下,新建log4net.config文件,并将以下内容添加进去,

<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">
    <param name="File" value="Log\\LogError\\" />
    <param name="AppendToFile" value="true" />
    <param name="MaxSizeRollBackups" value="100" />
    <param name="MaximumFileSize" value="10240" />
    <param name="StaticLogFileName" value="false" />
    <param name="DatePattern" value="yyyyMMdd&quot;.htm&quot;" />
    <param name="RollingStyle" value="Date" />
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="&lt;HR COLOR=red&gt;%n异常时间:%d [%t] &lt;BR&gt;%n异常级别:%-5p &lt;BR&gt;%n异 常 类:%c [%x] &lt;BR&gt;%n%m &lt;BR&gt;%n &lt;HR Size=1&gt;"  />
    </layout>
  </appender>
  <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
    <param name="File" value="Log\\LogInfo\\" />
    <param name="AppendToFile" value="true" />
    <param name="MaximumFileSize" value="102KB" />
    <param name="MaxSizeRollBackups" value="10" />
    <param name="StaticLogFileName" value="false" />
    <param name="DatePattern" value="yyyyMMdd&quot;.htm&quot;" />
    <param name="RollingStyle" value="Composite" />
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="&lt;HR COLOR=blue&gt;%n日志时间:%d [%t] &lt;BR&gt;%n日志级别:%-5p &lt;BR&gt;%n日 志 类:%c [%x] &lt;BR&gt;%n%m &lt;BR&gt;%n &lt;HR Size=1&gt;"  />
    </layout>
  </appender>
</log4net>

Step4、新建LogHelp类,代码如下:

 class LogHelp
    {

        public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");
        public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");
        private static object thisLock = new object();
        public static void WriteLog(string info, bool realWriteLog = true)
        {
            lock (thisLock)
            {
                if(realWriteLog)
                {
                    if (loginfo.IsInfoEnabled)
                    {
                        loginfo.Info(info);
                    }
                }
            }
        }

        public static void WriteLog(string info, Exception se,bool realWriteLog=true)
        {
            lock (thisLock)
            {
                if(realWriteLog)
                {
                    if (logerror.IsErrorEnabled)
                    {
                        logerror.Error(info, se);
                    }
                }
            }
        }
        /// <summary>
        /// 日志保留多少天
        /// </summary>
        /// <param name="logFilePath"></param>
        /// <param name="saveDays"></param>
        public static void SaveLogDays(string logFilePath, int saveDays)
        {
            lock (thisLock)
            {
                string[] logFileName = Directory.GetFiles(logFilePath);
                if (logFileName.Count() > saveDays)
                {
                    File.Delete(logFileName[0]);
                }
            }
        }
    }

Step5、客户端调用如下:

 LogHelp.WriteLog("123");
 LogHelp.WriteLog("456",new Exception ("错误"));

总结:
1) 以上要注意上述配置是按照日期+文件大小的格式,按照每天的格式,一天最多10个文件,超过10个则用最新的替代旧的文件,且每个文件的最大值为102KB。
2)如果只是按照文件日期配置的话,则将<param name="RollingStyle" value="Composite" />改为<param name="RollingStyle" value="Date" />,则文件按照每天一个文件的格式来记录。
3)如果只是按照文件大小配置的话,则将<param name="RollingStyle" value="Composite" />改为<param name="RollingStyle" value="Size" />,并且要执行文件名,因为不按照日期的话,日志就不知道log日志的文件名是什么了,也就是将<param name="File" value="Log\\LogInfo\\" />改为<param name="File" value="Log\\LogInfo\\logInfo.txt" />,将 <param name="File" value="Log\\LogError\\" />改为 <param name="File" value="Log\\LogError\\logError.txt" />即可。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

c#上位机

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值