zoukankan      html  css  js  c++  java
  • springboot log4j

    一、gradle 排除起步依赖中的logback

    //排除全局依赖
    configurations {
        compile.exclude module:'spring-boot-starter-logging'
    //    all*.exclude group: 'org.gradle.test.excludes', module: 'reports'
    }

    还有一种在部分排除

    // 添加起步依赖
        implementation ('org.springframework.boot:spring-boot-starter-web'){
            // 排除jar包依赖
    //        exclude module : 'spring-boot-starter-logging'
        }

    二、新建配置文件,默认放在resource目录下

    log4j2-XXXX.xml

    可以指定配置文件位置:

    logging.config=classpath:log4j2-spring.xml

    三、修改配置文件

    官网:http://logging.apache.org/log4j/2.x/log4j-spring-cloud-config/log4j-spring-cloud-config-client/index.html

    如果跟我一样英文不是太好的,可以看这篇博主(筱光)的博客https://blog.csdn.net/womeng2009/article/details/53510913

    为了避免博主哪天删了,下面是一些拷贝和记录

    log4j 用途与优点:

    1.    将信息送到控制台,文件,GUI组件等。

    2.    控制每条信息的输出格式。

    3.    将信息分类,定义信息级别,细致地控制日志的输出

    配置项:

    1.    日志级别

    trace:追踪,就是程序推进一下,可以写个trace输出

    debug:调试,一般作为最低级别,trace基本不用。

    info:输出重要的信息,使用较多

    warn:警告,有些信息不是错误信息,但也要给程序员一些提示。

    error:错误信息。用的也很多。

    fatal:致命错误。级别较高,这种级别不用调试了,重写吧……

    2.    输出源

    CONSOLE(输出到控制台)、FILE(输出到文件)等。

    3.    布局方式

    SimpleLayout:以简单的形式显示

    HTMLLayout:以HTML表格显示

    PatternLayout:自定义形式显示

    在Log4J2中基本采用PatternLayout自定义日志布局。

    自定义格式:

    %t:线程名称

    %p:日志级别

    %c:日志消息所在类名

    %m:消息内容

    %M:输出执行方法

    %d:发生时间,%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2011-10-18 22:10:28,921

    %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。

    %L:代码中的行数

    %n:换行

    使用案例:

    package com.log4j2;
     
    import org.apache.logging.log4j.Logger;
    import org.apache.logging.log4j.LogManager;
     
    public class test {
     
        static Logger logger = LogManager.getLogger(test.class.getName());
        
        public static boolean hello(){
            logger.trace("entry");    //等同于logger.entry();但此方法在新版本好像已经废弃
            
            logger.error("Did it again!");
            
            logger.info("这是info级信息");
     
            logger.debug("这是debug级信息");
            
            logger.warn("这是warn级信息");
            
            logger.fatal("严重错误");
            
            logger.trace("exit");
            
            return false;
        }
        
        public static void main(String[] args) {
            
            logger.trace("开始主程序");
            
            for(int i = 0; i < 10000; i++){
                logger.info("当前i:"+i);
                if(!test.hello()){
                    logger.error("hello");
                }
            }
            
            logger.trace("退出程序");
        }
    }

    简单定义:

    <?xml version="1.0" encoding="UTF-8"?>
    <Configuration status="INFO">
        <Appenders>
            <!--添加一个控制台追加器-->
            <Console name="Console" target="SYSTEM_OUT" follow="true">
                <PatternLayout>
                    <pattern>[%-5p] %d %c - %m%n</pattern>
                </PatternLayout>
            </Console>
            <!--添加一个文本追加器,文件位于根目录下,名为log.log-->
            <File name="File" fileName="log.log">
                <PatternLayout>
                    <pattern>[%-5p] %d %c - %m%n</pattern>
                </PatternLayout>
            </File>
        </Appenders>
        <Loggers>
            <Root level="info">
                <AppenderRef ref="Console" />
            </Root>
                <!--把org.springframework包下的所有日志输出到log文件,additivity="false"表示不输出到控制台-->
            <Logger name="org.springframework" level="info" additivity="false">
                <AppenderRef ref="File" />
            </Logger>
        </Loggers>
    </Configuration>

    复杂配置:

    <?xml version="1.0" encoding="UTF-8"?>  
    <configuration status="error">
    <!--     先定义所有的appender -->
        <appenders>
    <!--         这个输出控制台的配置 -->
            <Console name="Console" target="SYSTEM_OUT">
    <!--             控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
                <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
    <!--             这个都知道是输出日志的格式 -->
                <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
            </Console>
            
    <!--         文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用 -->
    <!--         append为TRUE表示消息增加到指定文件中,false表示消息覆盖指定的文件内容,默认值是true -->
            <File name="log" fileName="log/test.log" append="false">
                <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
            </File>
            
    <!--          添加过滤器ThresholdFilter,可以有选择的输出某个级别以上的类别  onMatch="ACCEPT" onMismatch="DENY"意思是匹配就接受,否则直接拒绝  -->
            <File name="ERROR" fileName="logs/error.log">
                <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
                <PatternLayout pattern="%d{yyyy.MM.dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            </File>
     
    <!--         这个会打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 -->
            <RollingFile name="RollingFile" fileName="logs/web.log"
                         filePattern="logs/$${date:yyyy-MM}/web-%d{MM-dd-yyyy}-%i.log.gz">
                <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
                <SizeBasedTriggeringPolicy size="2MB"/>
            </RollingFile>
        </appenders>
        
    <!--     然后定义logger,只有定义了logger并引入的appender,appender才会生效 -->
        <loggers>
    <!--         建立一个默认的root的logger -->
            <root level="trace">
                <appender-ref ref="RollingFile"/>
                <appender-ref ref="Console"/>
                <appender-ref ref="ERROR" />
                <appender-ref ref="log"/>
            </root>
     
        </loggers>
    </configuration>
  • 相关阅读:
    Hamming Distance
    变量
    Jupyter Notebook 快捷键使用指南
    XPath使用总结
    selenium调用webdriver异常
    漏洞挖掘 | 远程WWW服务支持TRACE请求
    漏洞挖掘 | 点击劫持
    漏洞挖掘 | 目录浏览漏洞
    漏洞挖掘 | 弱口令漏洞
    浅谈Linux下/etc/passwd文件
  • 原文地址:https://www.cnblogs.com/jony-it/p/11493575.html
Copyright © 2011-2022 走看看