pom.xml增加依赖
log4j大家應該再熟悉不過了,log4j2則是log4j的一次比較大的升級,底層使用disruptor重寫優化了異步輸出日志,性能得到極大提高。筆者曾將log4j、logback、log4j2做過性能對比,log4j2的確表現出絕對的優勢。話不多說,下面主要是貼出筆者在項目中不斷完善的log4j2配置文件。
pom.xml增加依賴
<!-- 日志log4j2 -->
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>${com-lmax-version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
log4j2.xml
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="off">
<Properties>
<Property name="LOG_HOME">logs</Property>
</Properties>
<!--先定義所有的appender -->
<Appenders>
<!-- 優先級從高到低分別是 OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL -->
<!-- 單詞解釋: Match:匹配 DENY:拒絕 Mismatch:不匹配 ACCEPT:接受 -->
<!-- DENY,日志將立即被拋棄不再經過其他過濾器; NEUTRAL,有序列表里的下個過濾器過接著處理日志; ACCEPT,日志會被立即處理,不再經過剩余過濾器。 -->
<!--輸出日志的格式
%d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生產時間
%p : 日志輸出格式
%c : logger的名稱
%m : 日志內容,即 logger.info("message")
%n : 換行符
%C : Java類名
%L : 日志輸出所在行數
%M : 日志輸出所在方法名
hostName : 本地機器名
hostAddress : 本地ip地址 -->
<!-- 控制臺 -->
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %t [%c:%L]-%m%n"/>
</Console>
<!-- lucas_device.log文件 -->
<RollingFile name="service_appender" fileName="${LOG_HOME}/lucas_device.log"
immediateFlush="false" append="true"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/lucas_device-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %t [%c:%L]-%m%n"/>
<Filters>
<!--如果是error級別拒絕 onMismatch="NEUTRAL",有序列表里的下個過濾器過接著處理日志; -->
<ThresholdFilter level="error" onMatch="DENY"
onMismatch="NEUTRAL"/>
<!--如果是info\warn輸出 onMismatch="DENY",日志將立即被拋棄不再經過其他過濾器 -->
<ThresholdFilter level="info" onMatch="ACCEPT"
onMismatch="DENY"/>
</Filters>
<Policies>
<!-- 如果啟用此配置,則日志會按文件名生成新壓縮文件, 即如果filePattern配置的日期格式為 %d{yyyy-MM-dd HH}
,則每小時生成一個壓縮文件, 如果filePattern配置的日期格式為 %d{yyyy-MM-dd} ,則天生成一個壓縮文件 -->
<TimeBasedTriggeringPolicy/>
<!-- 每個日志文件最大512MB -->
<SizeBasedTriggeringPolicy
size="512MB"/>
</Policies>
<DefaultRolloverStrategy>
<Delete basePath="${LOG_HOME}" maxDepth="2">
<IfFileName glob="*/lucas_device-*.log.gz"/>
<!-- 刪除30天前的文件 -->
<IfLastModified age="30d"/>
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
<!-- lucas_device_error.log文件 -->
<RollingFile name="service_appender_error" fileName="${LOG_HOME}/lucas_device_error.log"
immediateFlush="false" append="true"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/lucas_device_error-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %t [%c:%L]-%m%n"/>
<Filters>
<ThresholdFilter level="error" onMatch="ACCEPT"
onMismatch="DENY"/>
</Filters>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy
size="512MB"/>
</Policies>
<DefaultRolloverStrategy>
<Delete basePath="${LOG_HOME}" maxDepth="2">
<IfFileName glob="*/lucas_device_error-*.log.gz"/>
<IfLastModified age="30d"/>
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
<!-- lucas_device_mqtt.log文件 -->
<RollingFile name="service_appender_mqtt" fileName="${LOG_HOME}/lucas_device_mqtt.log"
immediateFlush="false" append="true"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/lucas_device_mqtt-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %t [%c:%L]-%m%n"/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy
size="512MB"/>
</Policies>
<DefaultRolloverStrategy>
<Delete basePath="${LOG_HOME}" maxDepth="2">
<IfFileName glob="*/lucas_device_mqtt-*.log.gz"/>
<IfLastModified age="7d"/>
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
<!-- lucas_device_restful.log文件 -->
<RollingFile name="service_restful" fileName="${LOG_HOME}/lucas_device_restful.log"
immediateFlush="false" append="true"
filePattern="${LOG_HOME}/$${date:yyyy-MM}/lucas_device_restful-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %t [%c:%L]-%m%n"www.oushengyule.com/>
<Policies>
<TimeBasedTriggeringPolicy/>
<SizeBasedTriggeringPolicy
size="512MB"/>
</Policies>
<DefaultRolloverStrategy>
<Delete basePath="${LOG_HOME}" maxDepth="2">
<IfFileName glob="*/lucas_device_restful-*.log.gz"/>
<IfLastModified age="7d"www.meiwanyule.cn />
</Delete>
</DefaultRolloverStrategy>
</RollingFile>
</Appenders>
<Loggers>
<AsyncRoot level="info" includeLocation="true"
additivity="false">
<AppenderRef ref="Console"www.yongshi123.cn/>
<AppenderRef ref="service_appender"/>
<AppenderRef ref="service_appender_error"/>
</AsyncRoot>
<AsyncLogger name="com.lucas.device.mqtt.message.MqttMessagePublishSolver" level="info" includeLocation="true"
additivity="false">
<AppenderRef ref="Console"/>
<AppenderRef ref="service_appender_mqtt"www.chengmingdL.com />
</AsyncLogger>
<AsyncLogger name="com.lucas.device.aop.MainLogAspect" level="info" includeLocation="true"
additivity="false">
<AppenderRef ref="Console"www.chengmyuLegw.cn/>
<AppenderRef ref="service_restful"/>
</AsyncLogger>
<AsyncLogger name="com.lucas.device.mapper" level="debug"
includeLocation="true" additivity="false">
<AppenderRef ref="Console"/>
<AppenderRef ref="service_restful"www.yuntianyuL.cn/>
</AsyncLogger>
</Loggers>
</Configuration>
配置文件主要是異步將系統日志輸出到不同文件。
lucas_device_error.log文件記錄了系統異常日志;
lucas_device_restful.log記錄的是用一個自定義注解@Logc記錄的所有restful請求的日志,以及sql執行語句;
lucas_device_mqtt.log記錄的是MqttMessagePublishSolver類輸出的日志;
最后其他日志都會輸出到lucas_device.log文件。
可以看到,在Loggers內部,我們指定了日志輸出的目標文件,而所有日志我們都設置在Console控制臺打印出來。
自定義日志注解@Logc詳細介紹
轉載于:https://www.cnblogs.com/qwangxiao/p/10943928.html
總結
以上是生活随笔為你收集整理的pom.xml增加依赖的全部內容,希望文章能夠幫你解決所遇到的問題。