行业资讯 2025年08月6日
0 收藏 0 点赞 309 浏览 2990 个字
摘要 :

文章目录 Log4j2多个Appender-XML配置 log4j2.xml是用于配置多个appender(如控制台appender和文件appender)的引用。它还配置了动态日志根路径。 Log4j2多个Appender-……




log4j2.xml是用于配置多个appender(如控制台appender和文件appender)的引用。它还配置了动态日志根路径。

Log4j2多个Appender-XML配置

下面的示例log4j2配置执行以下操作:

  • 使用动态日志根路径,其中将创建日志文件。通过将环境变量作为-DAPP_LOG_ROOT=c:/temp进行配置。
  • 演示在配置文件中定义属性常量的用法,例如下面的文件中的LOG_PATTERN。
  • 它使用LevelRangeFilter将不同的日志级别语句记录在不同的文件中,即一个文件中的调试日志和另一个文件中的错误日志。
  • 所有日志都将显示在控制台上。
<?xml version=\"1.0\" encoding=\"UTF-8\"?>
<Configuration status=\"WARN\" monitorInterval=\"30\">
 
    <Properties>
        <Property name=\"LOG_PATTERN\">%d{yyyy-MM-dd\'T\'HH:mm:ss.SSSZ} %p %m%n</Property>
    </Properties>
 
    <Appenders>
 
        <Console name=\"Console\" target=\"SYSTEM_OUT\" follow=\"true\">
            <PatternLayout pattern=\"${LOG_PATTERN}\"/>
        </Console>
         
    <RollingFile name=\"debugLog\" fileName=\"${sys:APP_LOG_ROOT}/application-debug.log\"
      filePattern=\"${sys:APP_LOG_ROOT}/application-debug-%d{yyyy-MM-dd}-%i.log\">
      <LevelRangeFilter minLevel=\"DEBUG\" maxLevel=\"DEBUG\" onMatch=\"ACCEPT\" onMismatch=\"DENY\"/>
      <PatternLayout pattern=\"${LOG_PATTERN}\"/>
      <Policies>
        <SizeBasedTriggeringPolicy size=\"19500KB\" />
      </Policies>
      <DefaultRolloverStrategy max=\"10\"/>
    </RollingFile>
     
    <RollingFile name=\"infoLog\" fileName=\"${sys:APP_LOG_ROOT}/application-info.log\"
      filePattern=\"${sys:APP_LOG_ROOT}/application-info-%d{yyyy-MM-dd}-%i.log\" >
      <LevelRangeFilter minLevel=\"INFO\" maxLevel=\"INFO\" onMatch=\"ACCEPT\" onMismatch=\"DENY\"/>
      <PatternLayout pattern=\"${LOG_PATTERN}\"/>
      <Policies>
        <SizeBasedTriggeringPolicy size=\"19500KB\" />
      </Policies>
      <DefaultRolloverStrategy max=\"10\"/>
    </RollingFile>
     
    <RollingFile name=\"errorLog\" fileName=\"${sys:APP_LOG_ROOT}/application-error.log\"
      filePattern=\"${sys:APP_LOG_ROOT}/application-error-%d{yyyy-MM-dd}-%i.log\" >
      <LevelRangeFilter minLevel=\"ERROR\" maxLevel=\"ERROR\" onMatch=\"ACCEPT\" onMismatch=\"DENY\"/>
      <PatternLayout pattern=\"${LOG_PATTERN}\"/>
      <Policies>
        <SizeBasedTriggeringPolicy size=\"19500KB\" />
      </Policies>
      <DefaultRolloverStrategy max=\"10\"/>
    </RollingFile>
     
    <RollingFile name=\"springLog\" fileName=\"${sys:APP_LOG_ROOT}/spring.log\"
      filePattern=\"${sys:APP_LOG_ROOT}/spring-%d{yyyy-MM-dd}-%i.log\" >
      <PatternLayout pattern=\"${LOG_PATTERN}\"/>
      <Policies>
        <SizeBasedTriggeringPolicy size=\"19500KB\" />
      </Policies>
      <DefaultRolloverStrategy max=\"1\"/>
    </RollingFile>
     
    <RollingFile name=\"aopLog\" fileName=\"${sys:APP_LOG_ROOT}/application-aop.log\"
      filePattern=\"${sys:APP_LOG_ROOT}/application-aop-%d{yyyy-MM-dd}-%i.log\" >
      <PatternLayout pattern=\"${LOG_PATTERN}\"/>
      <Policies>
        <SizeBasedTriggeringPolicy size=\"19500KB\" />
      </Policies>
      <DefaultRolloverStrategy max=\"1\"/>
    </RollingFile>
     
    </Appenders>
 
    <Loggers>
     
      <Logger name=\"com.howtodoinjava.app.aop\" additivity=\"false\">
        <AppenderRef ref=\"aopLog\" />
            <AppenderRef ref=\"Console\" />
        </Logger>
         
        <Logger name=\"com.howtodoinjava.app\" additivity=\"false\">
          <AppenderRef ref=\"debugLog\" />
          <AppenderRef ref=\"infoLog\"  />
            <AppenderRef ref=\"errorLog\" />
            <AppenderRef ref=\"Console\"  />
        </Logger>
         
        <Logger name=\"org.springframework\" additivity=\"false\">
            <AppenderRef ref=\"springLog\" />
            <AppenderRef ref=\"Console\"/>
        </Logger>
                 
        <Root level=\"all\">
            <AppenderRef ref=\"Console\"/>
        </Root>
 
    </Loggers>
 
</Configuration>

 

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/9573.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号