zoukankan      html  css  js  c++  java
  • 日志系列【springboot中使用日志的正确打开方式】

    参考链接:

    通用:https://www.cnblogs.com/handsome1013/p/11201316.html

    log4j2:https://www.cnblogs.com/bugzeroman/p/13737766.html

    1.本文主要介绍logj2,排除默认,加pom坐标

    <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
                <exclusions>
                    <!-- 排除掉logging,不使用logback,改用log4j2 -->
                    <exclusion>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-starter-logging</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-log4j2</artifactId>
            </dependency>
            <dependency>
                <groupId>com.lmax</groupId>
                <artifactId>disruptor</artifactId>
                <version>3.4.2</version>
            </dependency>

    2.若采用异步,则把上边最后一个依赖必须加上,并设置启动属性

    public static void main(String[] args) {
            System.setProperty("log4j2.contextSelector", "org.apache.logging.log4j.core.async.AsyncLoggerContextSelector");
            SpringApplication.run(SpringbootValidatorApplication.class, args);
        }

    3.log4j2.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <!--status:Log4j2内部日志的输出级别,设置为TRACE对研究Log4j2非常有用 -->
    <!--monitorInterval:定时检测配置文件的修改,有变化则自动重新加载配置,时间单位为秒,最小间隔为5s -->
    <Configuration status="WARN" monitorInterval="600">
        <!--properties:设置全局变量 -->
        <properties>
            <!--LOG_HOME:指定当前日志存放的目录 -->
            <property name="LOG_HOME">logs</property>
            <!--FILE_NAME:指定日志文件的名称 -->
            <property name="FILE_NAME">mybatis_plus_demo</property>
        </properties>
        <!--Appenders:定义日志输出目的地,内容和格式等 -->
        <Appenders>
            <!--Console:日志输出到控制台标准输出 -->
            <Console name="Console" target="SYSTEM_OUT">
                <!--pattern:日期,线程名,日志级别,日志名称,日志信息,换行 -->
                <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%L] - %msg%n" />
            </Console>
            <!--RollingFile:日志输出到文件,下面的文件都使用相对路径 -->
            <!--fileName:当前日志输出的文件名称 -->
            <!--filePattern:备份日志文件名称,备份目录为logs下面以年月命名的目录,备份时使用gz格式压缩 -->
            <RollingFile name="RollingFile" fileName="${LOG_HOME}/${FILE_NAME}.log"
                         filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd}-%i.log.gz">
                <!-- 输出日志事件调用者的完全限定名、源文件名和行号,注意可能会影响性能,请谨慎使用。  -->
                <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level [%l] - %msg%n" />
                <!--Policies:触发策略决定何时执行备份 -->
                <Policies>
                    <!--TimeBasedTriggeringPolicy:日志文件按照时间备份 -->
                    <!--interval:每1天分钟生成一个新文件,需要结合filePattern时间%d{yyyy-MM-dd} -->
                    <!--同理,如果要每1小时生成一个新文件,则改成%d{yyyy-MM-ddHH} -->
                    <!--modulate:对备份日志的生成时间纠偏,纠偏以0为基准进行,"0+interval"决定启动后第一次备份时间 -->
                    <TimeBasedTriggeringPolicy interval="1" modulate="true" />
                    <!--SizeBasedTriggeringPolicy:日志文件按照大小备份 -->
                    <!--size:指定日志文件最大为100MB,单位可以为KB、MB或GB -->
                    <SizeBasedTriggeringPolicy size="100MB" />
                </Policies>
                <!--DefaultRolloverStrategy:翻转策略决定如何执行备份 -->
                <!--max:最多保存5个日志备份文件,结合时间使用后,在每个时间段内最多有5个备份,多出来的会被覆盖 -->
                <!--compressionLevel:配置日志压缩级别,范围0-9,0不压缩,1压缩速度最快,9压缩率最好,目前只对于zip压缩文件类型有效 -->
                <DefaultRolloverStrategy max="5" compressionLevel="1">
                    <!--Delete:删除匹配到的过期备份日志文件 -->
                    <!--maxDepth:由于备份日志保存在${LOG_HOME}/$${date:yyyy-MM},所以目录深度设置为2 -->
                    <Delete basePath="${LOG_HOME}" maxDepth="2">
                        <!--IfFileName:匹配文件名称 -->
                        <!--glob:匹配2级目录深度下的以.log.gz结尾的备份文件 -->
                        <IfFileName glob="*/*.log.gz" />
                        <!--IfLastModified:匹配文件修改时间 -->
                        <!--age:匹配超过180天的文件,单位D、H、M、S分别表示天、小时、分钟、秒-->
                        <IfLastModified age="180D" />
                    </Delete>
                </DefaultRolloverStrategy>
            </RollingFile>
        </Appenders>
        <!--Loggers:定义日志级别和使用的Appenders -->
        <Loggers>
            <!--name: 打印日志的类的包路径 -->
            <!--additivity: true当前的Logger打印的日志附加到Root,false仅仅打印到RollingFile -->
            <Logger name="com.jiulong.springboot_validator" level="DEBUG" additivity="true">
                <AppenderRef ref="RollingFile" />
            </Logger>
            <!--dao:控制mybatis打印执行的SQL日志 -->
            <Logger name="com.jiulong.springboot_validator.dao" level="DEBUG" additivity="true">
                <AppenderRef ref="RollingFile" />
            </Logger>
            <!--Root:日志默认打印到控制台 -->
            <!--level日志级别: ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF -->
            <Root level="info">
                <AppenderRef ref="Console" />
            </Root>
        </Loggers>
    </Configuration>
  • 相关阅读:
    中国VR公司的详尽名单
    maven打包源代码sources.jar和javadoc.jar帮助文档
    中国计算机学会推荐国际学术刊物
    myhuiban会议,期刊,科研人员,计算机类会议大全
    如何写mysql的定时任务
    mysql系列命令解释
    Bootstrap 导航元素
    base64对文件进行加密
    我最在行 诗词 连续错误的
    <% %> in html
  • 原文地址:https://www.cnblogs.com/hujunwei/p/15559328.html
Copyright © 2011-2022 走看看