首页 > 编程语言 >java-log4j-xml配置 category、logger、boot 标签使用

java-log4j-xml配置 category、logger、boot 标签使用

时间:2022-10-28 15:04:08浏览次数:57  
标签:xml category java log warn info debug Logger log4j



java-log4j-xml配置 category、logger、boot 标签使用

一、节点说明:

root:基础日志配置、包括使用的输出器、日志级别等;


logger:自定义输出配置;


category:自定义输出配置;




logger、category 用法一致,可以配置通过 additivity 属性标记是否集成 root 配置;




二、maven 依赖:


<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>







log4j 配置:demo/src/main/resources/core/log4j.xml


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>


<!-- 控制台输出 -->
<appender name="stdout" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<!--最小级别-->
<param name="LevelMin" value="INFO"/>
</filter>
</appender>


<!-- 系统启动日志输出文件 -->
<appender name="fileAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="Encoding" value="UTF-8"/>
<param name="File" value="/logs/test_log4j_logs/system.log"/>
<param name="DatePattern" value="'.'yyyy-MM-dd"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<!--最小级别-->
<param name="LevelMin" value="INFO"/>
</filter>
</appender>


<!-- 测试 category 配置节 -->
<appender name="testCategoryAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="/logs/test_log4j_logs/test_category_logs.log"/>
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<!--最小级别-->
<param name="LevelMin" value="INFO" />
</filter>
</appender>


<!-- 测试 logger 配置节 -->
<appender name="testAppender" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="/logs/test_log4j_logs/test_logger_logs.log"/>
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<!--最小级别,小于 error 级别错误将不输出-->
<param name="LevelMin" value="ERROR" />
</filter>
</appender>


<!--自定义日志输出配置,additivity=是否继承 root 配置-->
<category name="testCategoryLogger" additivity="false">
<level value="INFO"></level>
<appender-ref ref="testCategoryAppender"></appender-ref>
<appender-ref ref="stdout"></appender-ref>
</category>
<!--自定义日志输出配置,additivity=是否继承 root 配置-->
<logger name="testLogger" additivity="false">
<!--级别-->
<level value="INFO"></level>
<!--输出器-->
<appender-ref ref="testAppender"></appender-ref>
<appender-ref ref="stdout"></appender-ref>
</logger>


<!--基础日志输出配置-->
<root>
<level value="INFO"/>
<!--输出器-->
<appender-ref ref="stdout"/>
<appender-ref ref="fileAppender"/>
</root>


</log4j:configuration>






三、测试代码:demo/src/test/java/com/example/demo/TestLog4j.java


package com.example.demo;


import org.apache.log4j.Logger;
import org.junit.Before;
import org.junit.Test;
import org.springframework.util.Log4jConfigurer;


import java.io.FileNotFoundException;


/**
* @author xiaojing.xie
* @create 2017-09-18
**/
public class TestLog4j {
@Before
public void before(){
try {
Log4jConfigurer.initLogging("classpath:core/log4j.xml");
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
@Test
public void test3(){
Logger log = Logger.getLogger("testLogger");
log.info("info");
log.debug("debug");
log.error("error");
log.warn("warn");
log.trace("trace");
}
@Test
public void test2(){
Logger log = Logger.getLogger("testCategoryLogger");
log.info("info");
log.debug("debug");
log.error("error");
log.warn("warn");
log.trace("trace");
}
@Test
public void test1(){
Logger log = Logger.getLogger("testAppender");
log.info("info");
log.debug("debug");
log.error("error");
log.warn("warn");
log.trace("trace");
}
}




四、测试说明:


主要观察 /logs/test_log4j_logs/ 路径下system.log、test_category_logs.log、test_logger_logs.log 三个文件的内容写入。





标签:xml,category,java,log,warn,info,debug,Logger,log4j
From: https://blog.51cto.com/u_4518216/5804880

相关文章

  • java-rabbitmq-交换机介绍
    java-rabbitmq-交换机介绍RabbitMQ的四种交换机直连交换机:Directexchange扇出交换机:Fanoutexchange主题交换机:Topicexchange首部交换机:H......
  • java-jsoup-解析html文本
    java-jsoup-解析html文本jsoup是一款Java的HTML解析器,可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API,可通过DOM,CSS以及类似于j......
  • java + springmvc 酷炫验证码分享
    java+springmvc酷炫验证码分享一、maven依赖<!--https://mvnrepository.com/artifact/com.github.bingoohuang/patchca--><!--验证码--><dependency><groupId>com......
  • Access to XMLHttpRequest at xxxx from origin xxx has been blocked by CORS poli
    错误:控制台报错; network自动发起了请求: 解决办法:找到\node_modules\sockjs-client\dist\sockjs.js 文件 然后crtl+g快捷键跳转到1603行,把他注释掉......
  • Java8新特性4:Optional
    1Optional介绍Optional类是一个可以为null的容器对象。如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象。Optional是个容器:它可以保存类型T的值,或者......
  • java-guava 布隆筛选器用法及比较
    java-guava布隆筛选器用法及比较布隆筛选器使用场景:   一般用于一个字符串是否存的预测,如爬虫是否抓取过这个URL等。优点:   对于特大的集合来说,检索快、占用内......
  • java springboot 2.x 环境搭建
    环境:javaversion1.8ApacheMaven3.2.2 ide:ideaspringboot:2.1.3.RELEASE创建步骤:1file=>new=>mudule...2选择SpringInitializr:modulesdk选择1.7,其他默认......
  • java-字符串拼接几种方法的性能比较
    java-字符串拼接几种方法的性能比较一、测试方法:String.format();MessageFormat.format();StringBuilder();二、测试结果:性能:StringBuilder>MessageFormat>String三......
  • 力扣907(java)-子数组的最小值之和(中等)
    题目:给定一个整数数组arr,找到min(b) 的总和,其中b的范围为arr的每个(连续)子数组。由于答案可能很大,因此返回答案模10^9+7。 示例1:输入:arr=[3,1,2,4]输......
  • java-floyd最短距离算法
    java-floyd最短距离算法publicstaticvoidmain(String[]args){MatrixDGmatrixDG=newMatrixDG();System.out.println("初始化邻接矩阵");matrixDG.print......