log4net配置datePattern导致日志文件名过长解决方案

目录

问题描述

要求

解决方案


问题描述

按照以下配置


  <log4net>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level - %message - %logger [%property{NDC}]%newline" />
      </layout>
    </appender>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="App_Data/logs/log" />
      <maximumFileSize value="500MB" />
      <appendToFile value="true" />
      <rollingStyle value="Composite" />
      <staticLogFileName value="false" />
      <datePattern value="yyyyMMdd'.log'" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="日志: %logger%newline时间: %date%newline级别: %level%newline线程: %thread%newline环境: %ndc%newline内容: %message%newline异常: %exception%newline-----------------------------------------------------%newline" />
      </layout>
    </appender>
    <root>
      <!-- Level:ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF -->
      <level value="ALL" />
      <appender-ref ref="ConsoleAppender" />
      <appender-ref ref="RollingFileAppender" />
    </root>
  </log4net>

每个进程会产生一个日志文件

 由于文件名过长,导致不能很方便地快速删除

请查看《文件名过长无法删除》

如何解决这个问题呢?

要求

1:日志文件名能区分日期(方便快速辨认)

2:日志文件名长度最好不超过20个字符

解决方案

既然是每个进程一个文件那我们就有进程id来命名文件名

  <datePattern value="yyyyMMdd'-'%processid'.log'" />

效果如下

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值