关注微信公众号:CodingTechWork,一起学习进步。

引言

  对于一个线上程序或者服务而言,重要的是要有日志输出,这样才能方便运维。而日志的输出需要有一定的规划,如日志命名、日志大小,日志分割的文件个数等。在Spring的框架下,我们可以使用log4j来进行日志的设置,高版本的SpringBoot会使用log4j2

介绍

log4j2概述

  截取官网的原话:Apache Log4j 2 is an upgrade to Log4j that provides significant improvements over its predecessor, Log4j 1.x, and provides many of the improvements available in Logback while fixing some inherent problems in Logback’s architecture.
  Log4j其实可以理解为log for java,所以是java的日志框架,提供日志服务,而Log4j 2是Log4j的升级版本,性能比logback好。
  日志级别优先级从低到高:ALL、DEBUG、 INFO、 WARN、 ERROR、FATAL、 OFF。一般官网建议就使用DEBUG、INFO、WARN和ERROR这四个,但是我们可以加一个ALL最低级别的来进行总日志的输出。日志的登记越高,打出的日志越少。

log4j2的pom依赖

        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><exclusions><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>

这边要注意的是:

  1. 在引入log4j2时,需要排除掉Logback日志框架的依赖即。
                    <artifactId>spring-boot-starter-logging</artifactId>
  1. 如果是1.3.x及以下版本的Spring Boot才支持log4j的日志配置。
        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><exclusions><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-log4j</artifactId></dependency>

log4j2.xml配置路径

  log4j2一般可以通过xml,json,yaml或者properties形式文件来实现,我们这边主要介绍xml文件格式。

默认路径

  引入log4j2依赖后,默认在src/main/resources目录下加入log4j2.xml配置文件对日志进行配置即可,然后在application.yml中进行访问路径的配置。

  示例如下:

  1. log4j2.xml部署位置
    在代码工程中的src/main/resources目录下放入配置文件。
  2. yml配置
#日志配置 无特殊需求无需更改
logging:config:  classpath:log4j2.xmllevel:root: INFOjavax.activation: infoorg.apache.catalina: INFOorg.apache.commons.beanutils.converters: INFOorg.apache.coyote.http11.Http11Processor: INFOorg.apache.http: INFOorg.apache.tomcat: INFOorg.springframework: INFOcom.chinamobile.cmss.bdpaas.resource.monitor: DEBUG

自定义部署位置

当然我们也可以在微服务部署的config/目录下放置,然后在application.yml中进行访问路径的配置。
  示例如下:我们的micro-service01部署中配置的log4j2.xml路径。

  1. log4j2.xml部署位置
[userA@linux01 config]$ pwd
/home/userA/SpringBoot/micro-service01/config
[userA@linux01 config]$ ll
total 24
-rwxr-xr-x 1 userA userA 5938 Sep  9 16:30 application.yml
-r-------- 1 userA userA 8342 Sep  8 16:33 log4j2.xml
  1. yml配置
#日志配置 无特殊需求无需更改
logging:config: /home/userA/SpringBoot/micro-service01/config/log4j2.xmllevel:root: INFOjavax.activation: infoorg.apache.catalina: INFOorg.apache.commons.beanutils.converters: INFOorg.apache.coyote.http11.Http11Processor: INFOorg.apache.http: INFOorg.apache.tomcat: INFOorg.springframework: INFOcom.chinamobile.cmss.bdpaas.resource.monitor: DEBUG

log4j2.xml配置详解

xml配置模板

<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
<!--<Configuration status="WARN" monitorInterval="30"> --><properties><property name="LOG_HOME">./service-logs</property></properties><Appenders><!--*********************控制台日志***********************--><Console name="consoleAppender" target="SYSTEM_OUT"><!--设置日志格式及颜色--><PatternLayoutpattern="%style{%d{ISO8601}}{bright,green} %highlight{%-5level} [%style{%t}{bright,blue}] %style{%C{}}{bright,yellow}: %msg%n%style{%throwable}{red}"disableAnsi="false" noConsoleNoAnsi="false"/></Console><!--*********************文件日志***********************--><!--all级别日志--><RollingFile name="allFileAppender"fileName="${LOG_HOME}/all.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/all-%d{yyyy-MM-dd}-%i.log.gz"><!--设置日志格式--><PatternLayout><pattern>%d %p %C{} [%t] %m%n</pattern></PatternLayout><Policies><!-- 设置日志文件切分参数 --><!--<OnStartupTriggeringPolicy/>--><!--设置日志基础文件大小,超过该大小就触发日志文件滚动更新--><SizeBasedTriggeringPolicy size="100 MB"/><!--设置日志文件滚动更新的时间,依赖于文件命名filePattern的设置--><TimeBasedTriggeringPolicy/></Policies><!--设置日志的文件个数上限,不设置默认为7个,超过大小后会被覆盖;依赖于filePattern中的%i--><DefaultRolloverStrategy max="100"/></RollingFile><!--debug级别日志--><RollingFile name="debugFileAppender"fileName="${LOG_HOME}/debug.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/debug-%d{yyyy-MM-dd}-%i.log.gz"><Filters><!--过滤掉info及更高级别日志--><ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/></Filters><!--设置日志格式--><PatternLayout><pattern>%d %p %C{} [%t] %m%n</pattern></PatternLayout><Policies><!-- 设置日志文件切分参数 --><!--<OnStartupTriggeringPolicy/>--><!--设置日志基础文件大小,超过该大小就触发日志文件滚动更新--><SizeBasedTriggeringPolicy size="100 MB"/><!--设置日志文件滚动更新的时间,依赖于文件命名filePattern的设置--><TimeBasedTriggeringPolicy/></Policies><!--设置日志的文件个数上限,不设置默认为7个,超过大小后会被覆盖;依赖于filePattern中的%i--><DefaultRolloverStrategy max="100"/></RollingFile><!--info级别日志--><RollingFile name="infoFileAppender"fileName="${LOG_HOME}/info.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log.gz"><Filters><!--过滤掉warn及更高级别日志--><ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/></Filters><!--设置日志格式--><PatternLayout><pattern>%d %p %C{} [%t] %m%n</pattern></PatternLayout><Policies><!-- 设置日志文件切分参数 --><!--<OnStartupTriggeringPolicy/>--><!--设置日志基础文件大小,超过该大小就触发日志文件滚动更新--><SizeBasedTriggeringPolicy size="100 MB"/><!--设置日志文件滚动更新的时间,依赖于文件命名filePattern的设置--><TimeBasedTriggeringPolicy interval="1" modulate="true /></Policies><!--设置日志的文件个数上限,不设置默认为7个,超过大小后会被覆盖;依赖于filePattern中的%i--><!--<DefaultRolloverStrategy max="100"/>--></RollingFile><!--warn级别日志--><RollingFile name="warnFileAppender"fileName="${LOG_HOME}/warn.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log.gz"><Filters><!--过滤掉error及更高级别日志--><ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/></Filters><!--设置日志格式--><PatternLayout><pattern>%d %p %C{} [%t] %m%n</pattern></PatternLayout><Policies><!-- 设置日志文件切分参数 --><!--<OnStartupTriggeringPolicy/>--><!--设置日志基础文件大小,超过该大小就触发日志文件滚动更新--><SizeBasedTriggeringPolicy size="100 MB"/><!--设置日志文件滚动更新的时间,依赖于文件命名filePattern的设置--><TimeBasedTriggeringPolicy/></Policies><!--设置日志的文件个数上限,不设置默认为7个,超过大小后会被覆盖;依赖于filePattern中的%i--><DefaultRolloverStrategy max="100"/></RollingFile><!--error及更高级别日志--><RollingFile name="errorFileAppender"fileName="${LOG_HOME}/error.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd}-%i.log.gz"><!--设置日志格式--><PatternLayout><pattern>%d %p %C{} [%t] %m%n</pattern></PatternLayout><Policies><!-- 设置日志文件切分参数 --><!--<OnStartupTriggeringPolicy/>--><!--设置日志基础文件大小,超过该大小就触发日志文件滚动更新--><SizeBasedTriggeringPolicy size="100 MB"/><!--设置日志文件滚动更新的时间,依赖于文件命名filePattern的设置--><TimeBasedTriggeringPolicy/></Policies><!--设置日志的文件个数上限,不设置默认为7个,超过大小后会被覆盖;依赖于filePattern中的%i--><DefaultRolloverStrategy max="100"/></RollingFile><!--json格式error级别日志--><RollingFile name="errorJsonAppender"fileName="${LOG_HOME}/error-json.log"filePattern="${LOG_HOME}/error-json-%d{yyyy-MM-dd}-%i.log.gz"><JSONLayout compact="true" eventEol="true" locationInfo="true"/><Policies><SizeBasedTriggeringPolicy size="100 MB"/><TimeBasedTriggeringPolicy interval="1" modulate="true"/></Policies></RollingFile></Appenders><Loggers><!-- 根日志设置 --><Root level="debug"><AppenderRef ref="allFileAppender" level="all"/><AppenderRef ref="consoleAppender" level="debug"/><AppenderRef ref="debugFileAppender" level="debug"/><AppenderRef ref="infoFileAppender" level="info"/><AppenderRef ref="warnFileAppender" level="warn"/><AppenderRef ref="errorFileAppender" level="error"/><AppenderRef ref="errorJsonAppender" level="error"/></Root><!--spring日志--><Logger name="org.springframework" level="debug"/><!--druid数据源日志--><Logger name="druid.sql.Statement" level="warn"/><!-- mybatis日志 --><Logger name="com.mybatis" level="warn"/><Logger name="org.hibernate" level="warn"/><Logger name="com.zaxxer.hikari" level="info"/><Logger name="org.quartz" level="info"/><Logger name="com.andya.demo" level="debug"/></Loggers></Configuration>

配置参数详解

Configuration

根节点Configuration中有两个常用的属性:status和monitorterval。如:<Configuration status="WARN" monitorInterval="30">

属性

  1. status:是用于指定log4j的级别;
  2. monitorterval:是用于指定log4j自动重新检测读取配置内容的间隔时间,单位为秒(s),最小值为5秒。

Properties

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><properties><property name="LOG_HOME">./service-logs</property></properties><Appenders><File name="MyFile" fileName="${LOG_HOME}/app.log"><PatternLayout><Pattern>%d %p %c{1.} [%t] %m%n</Pattern></PatternLayout></File></Appenders><Loggers><Root level="error"><AppenderRef ref="MyFile"/></Root></Loggers>
</Configuration>

变量配置,如模板中的<property name="LOG_HOME">./service-logs</property>,我们可以配置日志的路径。后续日志存放的前缀路径即为./service-logs下, <File name="MyFile" fileName="${LOG_HOME}/app.log">中配置了前缀,app.log就会存放在./service-logs下。

Appenders

Console

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><Appenders><Console name="STDOUT" target="SYSTEM_OUT"><PatternLayout pattern="%m%n"/></Console></Appenders><Loggers><Root level="error"><AppenderRef ref="STDOUT"/></Root></Loggers>
</Configuration>

  Console节点用于定义输出控制台的Appender。

属性

  1. name:用于指定Appender的名称;
  2. target:用于指定输出目标,一般是SYSTEM_OUTSYSTEM_ERR,默认是SYSTEM_OUT

节点

  1. PatternLayout:用于指定输出格式,不设置的话,默认为:%m%n

File

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><Appenders><File name="MyFile" fileName="logs/app.log"><PatternLayout><Pattern>%d %p %c{1.} [%t] %m%n</Pattern></PatternLayout></File></Appenders><Loggers><Root level="error"><AppenderRef ref="MyFile"/></Root></Loggers>
</Configuration>

  File节点用于将日志输出到指定文件,一般不用该节点,而使用RollingFile节点。

属性

  1. name:用于指定Appender的名称;
  2. fileName:用于指定日志文件的全路径;

节点

  1. PatternLayout:用于指定输出格式,不设置的话,默认为:%m%n

RollingFile

  RollingFile节点用于实现日志文件更动更新的Appender,当满足条件(日志大小、指定时间等)重命名或打包原日志文件进行归档,生成新日志文件用于日志写入。
  我们可以设置ALL、DEBUG、 INFO、 WARN、 ERROR这些级别的RollingFileAppender。

(1)基于大小的滚动策略
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><Appenders><RollingFile name="RollingFile" fileName="logs/app.log"filePattern="logs/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz"><PatternLayout><Pattern>%d %p %c{1.} [%t] %m%n</Pattern></PatternLayout><Policies><TimeBasedTriggeringPolicy /><SizeBasedTriggeringPolicy size="100 MB"/></Policies><DefaultRolloverStrategy max="10"/></RollingFile></Appenders><Loggers><Root level="error"><AppenderRef ref="RollingFile"/></Root></Loggers>
</Configuration>

  上述模板中,日志先写入logs/app.log中,每当文件大小达到100MB时或经过1天,按照在logs/2020-09/目录下以app-2020-09-09-1.log.gz格式对该日志进行压缩重命名并归档,并生成新的文件app.log进行日志写入。
  其中,filePattern属性的文件格式中%i就类似于一个整数计数器,受到<DefaultRolloverStrategy max="10"/>控制,要特别注意的是:当文件个数达到10个的时候会循环覆盖前面已归档的1-10个文件。若不设置该参数,默认为7

(2)基于时间间隔的滚动策略
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><Appenders><RollingFile name="RollingFile" fileName="logs/app.log"filePattern="logs/$${date:yyyy-MM}/app-%d{yyyy-MM-dd-HH}.log.gz"><PatternLayout><Pattern>%d %p %c{1.} [%t] %m%n</Pattern></PatternLayout><Policies><TimeBasedTriggeringPolicy interval="6" modulate="true"/></Policies></RollingFile></Appenders><Loggers><Root level="error"><AppenderRef ref="RollingFile"/></Root></Loggers>
</Configuration>

  上述模板中,日志先写入logs/app.log中,每当文件的时间间隔到达6小时(由%d{yyyy-MM-dd-HH}决定,也可以设置成%d{yyyy-MM-dd-HH-mm},则间隔为分钟级别),触发rollover操作。
  如上配置设置好后,10点的日志开始重启服务,则从11点触发一次rollover操作,生成2020-09-09-10.log.gz对该日志进行压缩重命名并归档,并生成新的文件app.log进行日志写入;然后,每间隔6小时,则下一次是17点触发一次,生成2020-09-09-17.log.gz对该日志进行压缩重命名并归档,并生成新的文件app.log进行日志写入。

(3)基于时间间隔和文件大小的滚动策略
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages=""><Appenders><RollingFile name="RollingFile" fileName="logs/app.log"filePattern="logs/$${date:yyyy-MM}/app-%d{yyyy-MM-dd-HH}-%i.log.gz"><PatternLayout><Pattern>%d %p %c{1.} [%t] %m%n</Pattern></PatternLayout><Policies><TimeBasedTriggeringPolicy interval="6" modulate="true"/><SizeBasedTriggeringPolicy size="100 MB"/></Policies></RollingFile></Appenders><Loggers><Root level="error"><AppenderRef ref="RollingFile"/></Root></Loggers>
</Configuration>

  上述模板中,日志先写入logs/app.log中,每当文件大小达到100MB或者当时间间隔到达6小时(由%d{yyyy-MM-dd-HH}决定),触发rollover操作,按照在logs/2020-09/目录下以app-2020-09-09-1.log.gz格式对该日志进行压缩重命名并归档,并生成新的文件app.log进行日志写入。

属性

  1. name:用于指定Appender的名称;
  2. fileName:用于指定日志文件的全路径;
  3. filePattern:用于指定分割文件的日志全路径(命名规则)。

节点

  1. PatternLayout:用于指定输出格式,不设置的话,默认为:%m%n
  2. Policies :设置日志文件切割参数;
  3. SizeBasedTriggeringPolicy:Policies的子节点,用于设置基于日志文件大小触发的滚动策略,size属性用来指定每个分割的日志文件大小。
  4. TimeBasedTriggeringPolicy:Policies的子节点,用于设置基于时间间隔触发的滚动策略,interval属性用于指定滚动时间间隔,默认是1小时,modulate属性是用于对interval进行偏移调节,默认为false。若为true,则第一次触发时是第一个小时触发,后续以interval间隔触发。
  5. CronTriggeringPolicy:Policies的子节点,用于设置基于Cron表达式触发的滚动策略。
  6. DefaultRolloverStrategy:设置默认策略设置。

Loggers

节点

  1. Root:用于指定项目的根日志,level属性表示日志输出级别,子节点AppenderRef用于指定输出到某个Appender,子节点的ref属性也就是前面的RollingFile中指定的name名称,子节点的level也是日志输出级别。
  2. Logger :用于指定日志的形式,指定不同包的日志级别,level属性表示日志输出级别,name属性用来指定该Logger所适用的类或者类的全路径。子节点AppenderRef用于指定日志输出到哪个Appender,若没有指定,默认集成自Root。

参考
log4j2的官网地址

SpringBoot—整合log4j2入门和log4j2.xml配置详解相关推荐

  1. mybatis 同名方法_MyBatis(四):xml配置详解

    目录 1.我们将 数据库的配置语句写在 db.properties 文件中 2.在 mybatis-configuration.xml 中加载db.properties文件并读取 通过源码我们可以分析 ...

  2. Java web之web.xml配置详解

    什么是web.xml web.xml是web项目的配置文件,一般的web工程都会用到web.xml来配置,方便大型开发.web.xml主要用来配置Filter,Listener,Servlet等.但是 ...

  3. JavaWeb web.xml配置详解

    参考: XML 教程 Java web之web.xml配置详解 Javaweb三大组件是:Servlet,Filter,Listener. 1.Servlet Servlet作为中转处理的容器,连接了 ...

  4. Ehcache 中ehcache.xml 配置详解和示例

    EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特点,是Hibernate中默认的CacheProvider. Ehcache是一种广泛使用的开源Java分布式缓存.主要面向通用缓存 ...

  5. Maven的settings.xml配置详解

    Maven的settings.xml配置详解 1 基本介绍 maven的两大配置文件:settings.xml和pom.xml.其中settings.xml是maven的全局配置文件,pom.xml则 ...

  6. web.xml配置详解

    往者不谏 来者可追 写作是最好的社交 新随笔 订阅 web.xml配置详解 Web.xml常用元素<web-app><display-name></display-nam ...

  7. Maven settings.xml配置详解

    首先:Maven中央仓库的搜索全部公共jar包的地址是,http://search.maven.org/ ===Maven基础-默认中央仓库============================== ...

  8. 160329(二)、web.xml配置详解

    1.启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取<listener>和<context-param>两个结点. 2.紧急着,容创建一个Servl ...

  9. Java web.xml 配置详解

    在项目中总会遇到一些关于加载的优先级问题,近期也同样遇到过类似的,所以自己查找资料总结了下,下面有些是转载其他人的,毕竟人家写的不错,自己也就不重复造轮子了,只是略加点了自己的修饰. 首先可以肯定的是 ...

最新文章

  1. 编程实现灰度处理函数
  2. Android Intent 大全[转载]
  3. tcp的3次握手4次挥手
  4. 报错日常——Tomcat45秒超时问题
  5. matlab mrst 工具箱 用共轭梯度法 找极值点
  6. Leetcode:Pow(x,n)
  7. 4米乘以12米CAD图_这篇文章解决了我多年CAD制图比例问题!
  8. 桌面 计算机 win7,计算机动态桌面,教您如何在win7中设置计算机动态桌面
  9. 【坚持每日一题9.21】整数的英语表示
  10. HHUOJ 1002 弟弟的作业(水题)
  11. 【踩坑】python: This install of SoX cannot process .mp3 files
  12. Java实现微信小程序校验图片是否含有违法违规内容
  13. mysql数据库select语句用法_mysql数据库select查询语句简单用法
  14. 中亦安图递交注册:拟募资6亿 年营收近12亿
  15. 华为内部的关于IC验证的经验总结
  16. _stprintf_s和_stscanf_s
  17. Linux查看和结束进程命令详解
  18. C++添加防火墙例外——检测目标程序不在例外列表时才进行添加,防止重复添加
  19. 37互娱java待遇,37互娱现场java一面
  20. Qt网络资源汇总(官网、源码、社区、博客)

热门文章

  1. 一个可以下载Github指定子文件夹的Chrome插件
  2. 【6.1】图片风格迁移 Neural Style Transfer
  3. PHPCMS商城:模块_购物车+订单模块(资源合集)
  4. Thinkphp内核无限坐席在线客服系统源码
  5. Typecho清新风格响应式网站主题
  6. 好看的简图动态背景图床源码 多接口聚合图床
  7. 蓝奏云批量下载v0.3修复版
  8. 沈阳计算机考试都学什么,沈阳计算机考研考什么科目
  9. 实用常识 | 文件都在C盘,一点儿都不圆润,盘它!
  10. linux的安全性能,技术|Linux 系统安全性能检查小记