由于原架构使用的是logback作为日志组件。当然该日志组件还是挺好用的,很方便的进行了日志分割等操作。但是该组件是同步的,所以高访问的时候可能会影响效率,这里就换成log4j2支持异步的日志组件。
1.pom中引入依赖Log4j Starter、disruptor依赖
(1)先exclusions排除掉默认的日志:
org.mybatis.spring.boot
mybatis-spring-boot-starter
${mybatis.version}
org.springframework.boot
spring-boot-starter-logging
(2) 引入log4j2相关依赖
org.springframework.boot
spring-boot-starter-log4j2
com.lmax
disruptor
3.3.6
注:disruptor是一个基于无锁化环形队列的高性能并发框架,log4j2就是借助它进行高性能日志异步输出的。
2.添加log4j2.xml配置文件
日志文件如下:
<?xml version="1.0" encoding="UTF-8"?>logs/activity
<RollingRandomAccessFile name=“FILE-INFO” fileName=“${logFilePath}/info/log-info.log”
filePattern=“${logFilePath}/info/log-info.%d{yyyy-MM-dd}-%i.log”>
<RollingRandomAccessFile name=“FILE-DEBUG” fileName=“${logFilePath}/debug/log-debug.log”
filePattern=“${logFilePath}/debug/log-debug.%d{yyyy-MM-dd}-%i.log”>
<RollingRandomAccessFile name=“FILE-WARN” fileName=“${logFilePath}/warn/log-warn.log”
filePattern=“${logFilePath}/warn/log-warn.%d{yyyy-MM-dd}-%i.log”>
<RollingRandomAccessFile name=“FILE-ERROR” fileName=“${logFilePath}/error/log-error.log”
filePattern=“${logFilePath}/error/log-error.%d{yyyy-MM-dd}-%i.log”>
3.添加log4j2.component.properties文件
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/b9ca9e3b8d77de1dd7360bc6138f6c17.jpeg)
最后
给大家送一个小福利
附高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
alt=“img” style=“zoom: 33%;” />
最后
给大家送一个小福利
[外链图片转存中…(img-E3cioTRO-1713301051960)]
附高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。
[外链图片转存中…(img-qIfS4otc-1713301051960)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!