第三篇 SpringBoot整合log4j2详解
源代码:https://pan.baidu.com/s/1d1Lwv1gIvVNltIKVWeEseA
提取码:wff0
SpringBoot整合Log4j2步骤:
1、删除spring-boot-starter-parent默认使用spring-boot-starter-logging依赖
2、在pom.xml中增加spring-boot-starter-log4j2依赖
3、创建log4j2.xml文件即可
4、执行,指定目录会生成相应的log文件
1:删除spring-boot-starter-logging见下图,打开pom.xml文件最终定位到spring-boot-dependencies文件,在此文件中将Logging依赖注释掉即可

将spring-boot-starter-logging注释后别忙着执行或debug会报错:SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
将spring-boot-starter-log4j2依赖添加到pom.xml后就没这个问题了
注意:下面version版本,2.2.7.RELEASE会失效,可能是版本不匹配,所以使用下面的版本同截图
org.springframework.boot
spring-boot-starter-parent
2.2.4.RELEASE
2:将下面依赖添加到pom.xml文件中
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>
</dependencies>
3:在src.java.main.resources目录下创建log4j2.xml文件 log4j2.xml文件内容如下:
    <!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!--
	自定义命名格式:
	%d:发生时间,%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2020-02-20 22:10:28,921
	%F:输出所在的类文件名
	%t:线程名称
	%p:日志级别
	%c:日志消息所在类名
	%m:消息内容
	%M:输出所在函数名
	%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
	%l:执行的函数名(类名称:行号)com.core.LogHelper.aroundService(LogHelper.java:32)
	%n:换行
	%i:从1开始自增数字
	%-5level:输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0
	“${sys:user.home}”是HOME目录 如:C:\Users\heave, 此处指定任意目录如:D:\logs
-->
<!--设置log4j2自身log级别为warn,每间隔30秒数自动检测配置是否发生修改,并重新配置-->
<configuration status="warn" monitorInterval="30">
	<Properties>
		<!-- 日志显示模板,显示内容的格式如下 -->
		<!-- [21:55:33:047] [INFO] - org.apache.juli.logging.DirectJDKLog.log(DirectJDKLog.java:173) - Initializing Spring embedded WebApplicationContext -->
		<Property name="log_pattern" value="[%d{HH:mm:ss:SSS}] [%p] - %l - %m%n"/>
		<!-- 保存日志文件目录 -->
		<!--<Property name="file_path" value="${sys:user.home}/logs"/>-->
		<Property name="file_path" value="C:/logs"/>
		<!-- 日志文件的最大容量,超过该值就进行备份 -->
		<Property name="file_max_size" value="30MB"/>
		<!-- 备份的文件夹名称 如下为:2020-02 -->
		<Property name="backup_folder" value="$${date:yyyy-MM}"/>
		<!-- 备份文件的后缀,日志文件超过file_max_size会备份到filePattern指定的目录下 -->
		<Property name="backup_file_suffix" value="-%d{yyyy-MM-dd}-%i.log"/>
	</Properties>
	<!--定义appender-->
	<appenders>
		<!--控制台的输出配置-->
		<console name="Console" target="SYSTEM_OUT">
			<!-- 设置控制台只输出INFO及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) -->
			<ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
			<!--输出日志的格式-->
			<PatternLayout pattern="${log_pattern}"/>
		</console>
		<!-- 所有的日志信息会打印到此文件中,append=false每次启动程序会自动清空 -->
		<!-- <File name="all" fileName="${file_path}/all.log" append="true">
			<PatternLayout pattern="${log_pattern}"/>
		</File>-->
		<!--
		该RollingFile存储INFO级别的日志,
		默认存储到 fileName 文件中
		超过SizeBasedTriggeringPolicy的设定值,则存储到 filePattern 文件中
		-->
		<RollingFile name="RollingFileInfo" fileName="${file_path}/info.log"
					 filePattern="${file_path}/${backup_folder}/info${backup_file_suffix}">
			<!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
			<ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
			<!-- 写入日志文件的模板 -->
			<PatternLayout pattern="${log_pattern}"/>
			<Policies>
				<TimeBasedTriggeringPolicy/>
				<SizeBasedTriggeringPolicy size="${file_max_size}"/>
			</Policies>
			<!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,超过该数量,会滚动删除前面的记录 -->
			<DefaultRolloverStrategy max="20"/>
		</RollingFile>
		<RollingFile name="RollingFileWarn" fileName="${file_path}/warn.log"
					 filePattern="${file_path}/${backup_folder}/warn${backup_file_suffix}">
			<ThresholdFilter level="WARN" onMatch="ACCEPT" onMismatch="DENY"/>
			<PatternLayout pattern="${log_pattern}"/>
			<Policies>
				<TimeBasedTriggeringPolicy/>
				<SizeBasedTriggeringPolicy size="${file_max_size}"/>
			</Policies>
		</RollingFile>
		<RollingFile name="RollingFileError" fileName="${file_path}/error.log"
					 filePattern="${file_path}/${backup_folder}/error${backup_file_suffix}">
			<ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
			<PatternLayout pattern="${log_pattern}"/>
			<Policies>
				<TimeBasedTriggeringPolicy/>
				<SizeBasedTriggeringPolicy size="${file_max_size}"/>
			</Policies>
		</RollingFile>
	</appenders>
	<!-- 只有定义了logger并使用appender-ref,appender才会生效 -->
	<loggers>
		<!--过滤掉spring和hibernate的一些无用的debug信息-->
		<logger name="org.springframework" level="INFO"/>
		<logger name="org.mybatis" level="INFO">
			<!-- 添加如下设置,控制台会再打印一次 -->
			<AppenderRef ref="Console"/>
		</logger>
		<root level="INFO">
			<appender-ref ref="Console"/>
			<appender-ref ref="RollingFileInfo"/>
			<appender-ref ref="RollingFileWarn"/>
			<appender-ref ref="RollingFileError"/>
		</root>
	</loggers>
</configuration>
项目目录结构如下:

项目运行生成的文件如下:

源代码:https://pan.baidu.com/s/1d1Lwv1gIvVNltIKVWeEseA
提取码:wff0
第三篇 SpringBoot整合log4j2详解的更多相关文章
- SaltStack 入门到精通第三篇:Salt-Minion配置文件详解
		
SaltStack 入门到精通第三篇:Salt-Minion配置文件详解 作者:ArlenJ 发布日期:2014-06-09 17:52:16 ##### 主要配置设置 ##### 配置 默认值 ...
 - java三篇博客转载 详解-vector,stack,queue,deque
		
博客一:转载自http://shmilyaw-hotmail-com.iteye.com/blog/1825171 java stack的详细实现分析 简介 我们最常用的数据结构之一大概就是stack ...
 - (三)SpringBoot之配置文件详解:Properties和YAML
		
一.配置文件的生效顺序,会对值进行覆盖: 1. @TestPropertySource 注解 2. 命令行参数 3. Java系统属性(System.getProperties()) 4. 操作系统环 ...
 - 【JUC系列第三篇】-CAS算法详解
		
作者 : 毕来生 微信: 878799579 1.CAS是什么? CAS是英文单词(Compare-And-Swap)的缩写,中文意思是:比较并替换.CAS需要有3个操作数:内存地址V,旧的预期值A, ...
 - Springboot整合log4j2日志全解
		
目录 常用日志框架 日志门面slf4j 为什么选用log4j2 整合步骤 引入Jar包 配置文件 配置文件模版 配置参数简介 Log4j2配置详解 简单使用 使用lombok工具简化创建Logger类 ...
 - SpringBoot与PageHelper的整合示例详解
		
SpringBoot与PageHelper的整合示例详解 1.PageHelper简介 PageHelper官网地址: https://pagehelper.github.io/ 摘要: com.gi ...
 - Springboot mini - Solon详解(三)- Solon的web开发
		
Springboot min -Solon 详解系列文章: Springboot mini - Solon详解(一)- 快速入门 Springboot mini - Solon详解(二)- Solon ...
 - Apache2.2+Tomcat7.0整合配置详解
		
一.简单介绍 Apache.Tomcat Apache HTTP Server(简称 Apache),是 Apache 软件基金协会的一个开放源码的网页服务器,可以在 Windows.Unix.Lin ...
 - Springboot mini - Solon详解(四)- Solon的事务传播机制
		
Springboot min -Solon 详解系列文章: Springboot mini - Solon详解(一)- 快速入门 Springboot mini - Solon详解(二)- Solon ...
 
随机推荐
- LeetCode10 Hard,带你实现字符串的正则匹配
			
本文始发于个人公众号:TechFlow 这是LeetCode的第10题,题目关于字符串的正则匹配,我们先来看题目相关信息: Link Regular Expression Matching Diffi ...
 - KVM管理工具 WebVirtMgr
			
WEB管理工具 WebVirtMgr WebVirtMgr是一个基于libvirt的Web界面,用于管理虚拟机.它允许您创建和配置新域,并调整域的资源分配.VNC查看器为来宾域提供完整的图形控制台.K ...
 - JZOJ4238 纪念碑
			
Description 2034年,纪念中学决定修建校庆100周年纪念碑,作为杰出校友的你被找了过来,帮校方确定纪念碑的选址. 纪念中学的土地可以看作是一个长为n,宽为m的矩形.它由n* m个1*1的 ...
 - Python处理URL编码
			
我们在访问网站时,有很多连接都是有一些特殊符号组成,例如,我在百度搜索“大鱼海棠”,结果可以看到它的搜索出来的链接是: https://www.baidu.com/s?wd=%E5%A4%A7%E9% ...
 - linux--->阿里云centos6.9安装yii2报错
			
阿里云centos6.9安装yii2报错 错误显示:Warning: require(/vendor/autoload.php): failed to open stream: No such fil ...
 - mybatis 源码分析中的知识点
			
1. resultMap 和 resultType 之间的优劣 resultMap: 在联合查询的时候, 可以不用写Join (因为在resultMap 的定义里面已经写了这些东西了<asso ...
 - SpringMVC进阶(二)
			
一.高级参数绑定 1.1. 绑定数组 Controller方法中可以用String[]接收,或者pojo的String[]属性接收.两种方式任选其一即可. /** * 包装类型 绑定数组类型,可以使用 ...
 - Hibernate(四)
			
==================================投影(查询)=============================投影查询:查询一个持久化类的一个或多个属性值 1.将每条 ...
 - JDBC——CreateStatement和PrepareStatement作用区别
			
本文主要讲了PrepareStatement和CreateStatement的作用区别,大家可以一起学习!走后端的小伙伴都会必修JDBC,在前段时间作者实训期间,看到老师举例的时候用了CreateSt ...
 - 实验1:  Cisco路由器基础配置
			
实验 1: Cisco路由器基础配置 1. 路由器的运行模式:Router> 用户模式,通常用来查看统计信息,但不能修改路由器的设置.Router# 特许模式,可以查看并修改 ...