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" />即可。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 在VS2019中编译log4cxx的过程相对较为复杂,以下是一种可能的方法: 1. 首先,从log4cxx的官方网站或GitHub页面上下载源代码文件,通常为一个压缩包文件。 2. 解压缩源代码文件到一个合适的位置,然后打开VS2019。 3. 在VS2019中,选择“文件”菜单,然后选择“新建”→“项目”。 4. 在项目面板中,选择“Visual C++”→“空项目”,并为项目指定一个名称。 5. 右键单击解决方案管理器中的“源文件”文件夹,选择“添加”→“现有项”。 6. 在弹出的对话框中,浏览并选择已解压的log4cxx源代码文件夹中的相关源文件。一般来说,这些文件主要位于“src”文件夹下。 7. 在解决方案管理器中,右键单击项目名称,选择“属性”。 8. 在属性面板中,选择“C/C++”→“常规”,然后编辑“附加包含目录”一栏,添加log4cxx源代码文件夹的路径。 9. 继续在属性面板中,选择“链接器”→“常规”,然后编辑“附加库目录”一栏,添加log4cxx库文件的路径。 10. 在“链接器”下的“输入”一栏中,编辑“附加依赖项”一栏,添加log4cxx库文件的名称,通常为“log4cxx.lib”。 11. 点击“确定”保存更改后,即可开始编译log4cxx。 12. 最后,在代码中引用log4cxx的头文件,即可使用相关的log4cxx功能。 这是一个大致的过程,具体细节可能因log4cxx源代码的版本和配置而有所差异。在实际操作中,可能还需要进一步配置和调试,以确保编译成功。 ### 回答2: 在VS2019中编译log4cxx需要以下步骤: 1. 下载log4cxx库:首先,你需要从Apache log4cxx的官方网站上下载log4cxx的库文件。确保下载与你的VS2019版本和操作系统兼容的库文件。 2. 安装CMake工具:如果你的版本不包含CMake工具,你需要单独下载和安装它。CMake是一个跨平台的开源工具,用于自动生成各种不同平台上的编译配置文件。 3. 生成项目配置:打开CMake工具,在"CMake source path"字段中选择log4cxx的源代码文件夹,在"CMake build path"字段中选择一个新文件夹作为编译输出目录。点击"Configure"按钮,选择你要生成的VS2019版本(例如,选择生成VS2019的Win64工程)。 4. 设置编译选项:在"CMake Cache"中,你可以配置各种编译选项,例如Debug和Release模式、目标平台等。根据你的需求进行配置,然后点击"Configure"和"Generate"按钮。 5. 打开VS2019项目:在CMake生成的文件夹中找到生成的VS2019项目文件(通常是.sln文件),双击打开。 6. 编译项目:在VS2019中,选择编译模式(例如Debug或Release)和目标平台,然后点击"生成"按钮开始编译log4cxx库。 7. 设置项目依赖项:如果在编译过程中出现依赖项错误,你需要手动设置项目的依赖项,确保所需的库文件正确链接。 8. 构建项目:重新构建项目以应用所做的更改。 9. 检查编译结果:在编译成功后,你可以在输出目录中找到生成的log4cxx库文件。将该文件与你的项目进行链接。 通过以上步骤,你应该能够在VS2019中成功编译log4cxx库。请注意,在编译过程中可能会遇到一些问题,例如版本不兼容、缺失库文件等。在遇到问题时,你可以查阅log4cxx的官方文档或在相关的开发者社区中寻求帮助。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

c#上位机

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

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

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

打赏作者

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

抵扣说明:

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

余额充值