您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“怎么使用log4j2自定義配置文件位置和文件名”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么使用log4j2自定義配置文件位置和文件名”吧!
我們使用log4j2一般做法是將log4j2.xml文件放在資源文件夾根目錄。對(duì)于有強(qiáng)迫癥的開發(fā)者來說,我更喜歡在資源文件夾下新建包或文件夾,然后把配置文件放在里面。本博客將介紹如何自定義log4j2.xml文件的位置和文件名。
<!-- 系統(tǒng)日志配置監(jiān)聽器 --> <listener> <listener-class>edu.example.holder.system.Log4j2ConfigListener</listener-class> </listener> <context-param> <description>日志配置文件的路徑</description> <param-name>log4j.configurationFile</param-name> <param-value>log4j/log4j2.xml</param-value> </context-param>
Log4j2ConfigListener類是自定義的類,實(shí)現(xiàn)ServletContextListener接口,這樣tomcat啟動(dòng)時(shí)可以更改日志配置文件的默認(rèn)路徑和文件名。
package edu.example.holder.system; import java.util.Enumeration; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; import org.apache.logging.log4j.core.config.Configurator; public class Log4j2ConfigListener implements ServletContextListener { private static final String KEY = "log4j.configurationFile"; @Override public void contextDestroyed(ServletContextEvent arg0) { } @Override public void contextInitialized(ServletContextEvent arg0) { String fileName = getContextParam(arg0); Configurator.initialize("Log4j2", "classpath:" + fileName); } @SuppressWarnings("unchecked") private String getContextParam(ServletContextEvent event) { Enumeration<String> names = event.getServletContext().getInitParameterNames(); while (names.hasMoreElements()) { String name = names.nextElement(); String value = event.getServletContext().getInitParameter(name); if(name.trim().equals(KEY)) { return value; } } return null; } }
<?xml version="1.0" encoding="UTF-8"?> <!-- status : 這個(gè)用于設(shè)置log4j2自身內(nèi)部的信息輸出,可以不設(shè)置,當(dāng)設(shè)置成trace時(shí),會(huì)看到log4j2內(nèi)部各種詳細(xì)輸出 monitorInterval : Log4j能夠自動(dòng)檢測(cè)修改配置文件和重新配置本身, 設(shè)置間隔秒數(shù)。 注:本配置文件的目標(biāo)是將不同級(jí)別的日志輸出到不同文件,最大2MB一個(gè)文件, 文件數(shù)據(jù)達(dá)到最大值時(shí),舊數(shù)據(jù)會(huì)被壓縮并放進(jìn)指定文件夾 --> <Configuration status="WARN" monitorInterval="600"> <Properties> <!-- 配置日志文件輸出目錄,此配置將日志輸出到tomcat根目錄下的指定文件夾 --> <Property name="LOG_HOME">${sys:catalina.home}/WebAppLogs/SSHExample</Property> </Properties> <Appenders> <!--這個(gè)輸出控制臺(tái)的配置,這里輸出除了warn和error級(jí)別的信息到System.out--> <Console name="console_out_appender" target="SYSTEM_OUT"> <!-- 控制臺(tái)只輸出level及以上級(jí)別的信息(onMatch),其他的直接拒絕(onMismatch) --> <ThresholdFilter level="warn" onMatch="DENY" onMismatch="ACCEPT"/> <!-- 輸出日志的格式 --> <PatternLayout pattern="%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n"/> </Console> <!--這個(gè)輸出控制臺(tái)的配置,這里輸出warn和error級(jí)別的信息到System.err,在eclipse控制臺(tái)上看到的是紅色文字--> <Console name="console_err_appender" target="SYSTEM_ERR"> <!-- 控制臺(tái)只輸出level及以上級(jí)別的信息(onMatch),其他的直接拒絕(onMismatch) --> <ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY"/> <!-- 輸出日志的格式 --> <PatternLayout pattern="%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n"/> </Console> <!-- TRACE級(jí)別日志 --> <!-- 設(shè)置日志格式并配置日志壓縮格式,壓縮文件獨(dú)立放在一個(gè)文件夾內(nèi), 日期格式不能為冒號(hào),否則無法生成,因?yàn)槲募辉试S有冒號(hào),此appender只輸出trace級(jí)別的數(shù)據(jù)到trace.log --> <RollingRandomAccessFile name="trace_appender" immediateFlush="true" fileName="${LOG_HOME}/trace.log" filePattern="${LOG_HOME}/trace/trace - %d{yyyy-MM-dd HH_mm_ss}.log.gz"> <PatternLayout> <pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern> </PatternLayout> <Policies><!-- 兩個(gè)配置任選其一 --> <!-- 每個(gè)日志文件最大2MB --> <SizeBasedTriggeringPolicy size="2MB"/> </Policies> <Filters><!-- 此Filter意思是,只輸出debug級(jí)別的數(shù)據(jù) --> <!-- DENY,日志將立即被拋棄不再經(jīng)過其他過濾器; NEUTRAL,有序列表里的下個(gè)過濾器過接著處理日志; ACCEPT,日志會(huì)被立即處理,不再經(jīng)過剩余過濾器。 --> <ThresholdFilter level="debug" onMatch="DENY" onMismatch="NEUTRAL"/> <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/> </Filters> </RollingRandomAccessFile> <!-- DEBUG級(jí)別日志 --> <!-- 設(shè)置日志格式并配置日志壓縮格式,壓縮文件獨(dú)立放在一個(gè)文件夾內(nèi), 日期格式不能為冒號(hào),否則無法生成,因?yàn)槲募辉试S有冒號(hào),此appender只輸出debug級(jí)別的數(shù)據(jù)到debug.log --> <RollingRandomAccessFile name="debug_appender" immediateFlush="true" fileName="${LOG_HOME}/debug.log" filePattern="${LOG_HOME}/debug/debug - %d{yyyy-MM-dd HH_mm_ss}.log.gz"> <PatternLayout> <pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern> </PatternLayout> <Policies><!-- 兩個(gè)配置任選其一 --> <!-- 每個(gè)日志文件最大2MB --> <SizeBasedTriggeringPolicy size="2MB"/> <!-- 如果啟用此配置,則日志會(huì)按文件名生成新壓縮文件, 即如果filePattern配置的日期格式為 %d{yyyy-MM-dd HH} ,則每小時(shí)生成一個(gè)壓縮文件, 如果filePattern配置的日期格式為 %d{yyyy-MM-dd} ,則天生成一個(gè)壓縮文件 --> <!-- <TimeBasedTriggeringPolicy interval="1" modulate="true" /> --> </Policies> <Filters><!-- 此Filter意思是,只輸出debug級(jí)別的數(shù)據(jù) --> <!-- DENY,日志將立即被拋棄不再經(jīng)過其他過濾器; NEUTRAL,有序列表里的下個(gè)過濾器過接著處理日志; ACCEPT,日志會(huì)被立即處理,不再經(jīng)過剩余過濾器。 --> <ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL"/> <ThresholdFilter level="debug" onMatch="ACCEPT" onMismatch="DENY"/> </Filters> </RollingRandomAccessFile> <!-- INFO級(jí)別日志 --> <RollingRandomAccessFile name="info_appender" immediateFlush="true" fileName="${LOG_HOME}/info.log" filePattern="${LOG_HOME}/info/info - %d{yyyy-MM-dd HH_mm_ss}.log.gz"> <PatternLayout> <pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern> </PatternLayout> <Policies> <SizeBasedTriggeringPolicy size="2MB"/> </Policies> <Filters> <ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/> <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/> </Filters> </RollingRandomAccessFile> <!-- WARN級(jí)別日志 --> <RollingRandomAccessFile name="warn_appender" immediateFlush="true" fileName="${LOG_HOME}/warn.log" filePattern="${LOG_HOME}/warn/warn - %d{yyyy-MM-dd HH_mm_ss}.log.gz"> <PatternLayout> <pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern> </PatternLayout> <Policies> <SizeBasedTriggeringPolicy size="2MB"/> </Policies> <Filters> <ThresholdFilter level="error" onMatch="DENY" onMismatch="NEUTRAL"/> <ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY"/> </Filters> </RollingRandomAccessFile> <!-- ERROR級(jí)別日志 --> <RollingRandomAccessFile name="error_appender" immediateFlush="true" fileName="${LOG_HOME}/error.log" filePattern="${LOG_HOME}/error/error - %d{yyyy-MM-dd HH_mm_ss}.log.gz"> <PatternLayout> <pattern>%5p [%t] %d{yyyy-MM-dd HH:mm:ss} (%F:%L) %m%n</pattern> </PatternLayout> <Policies> <SizeBasedTriggeringPolicy size="2MB"/> </Policies> <Filters> <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/> </Filters> </RollingRandomAccessFile> </Appenders> <Loggers> <!-- 配置日志的根節(jié)點(diǎn) --> <root level="trace"> <appender-ref ref="console_out_appender"/> <appender-ref ref="console_err_appender"/> <appender-ref ref="trace_appender"/> <appender-ref ref="debug_appender"/> <appender-ref ref="info_appender"/> <appender-ref ref="warn_appender"/> <appender-ref ref="error_appender"/> </root> <!-- 第三方日志系統(tǒng) --> <logger name="org.springframework.core" level="info"/> <logger name="org.springframework.beans" level="info"/> <logger name="org.springframework.context" level="info"/> <logger name="org.springframework.web" level="info"/> <logger name="org.jboss.netty" level="warn"/> <logger name="org.apache.http" level="warn"/> </Loggers> </Configuration>
如下:
(文件名必須規(guī)范,否則系統(tǒng)無法找到配置文件):
classpath下名為 log4j-test.json 或者log4j-test.jsn文件
classpath下名為 log4j2-test.xml
classpath下名為 log4j.json 或者log4j.jsn文件
classpath下名為 log4j2.xml
static Logger logger = LogManager.getLogger(MyApplication.class.getName()); private static Logger logger = LogManager.getLogger("MyApplication");
所以介紹一下xml配置:
1.首先要配幾個(gè)要用到的appender,這些appender功能不一樣,比如有常規(guī)輸出,重大異常輸出,你可能需要他們輸出形式或者輸出的文件不同,這些都可以在appender中配置
2.appender里面的一些配置說明:
name
:appender的名稱
fileName
:輸出文件和名稱
append
:是否追加,true表示追加內(nèi)容到所在的日志,false表示每次都覆蓋
filePattern
:表示當(dāng)日志到達(dá)指定的大小或者時(shí)間,產(chǎn)生新日志時(shí),舊日志的命名路徑
PatternLayout
:指定輸出日志的格式,具體代表的意思見前面的博客中
Policies
:策略,表示日志什么時(shí)候應(yīng)該產(chǎn)生新日志,可以有時(shí)間策略和大小策略等
ThresholdFilter
:過濾器,log4j2中有很多的filter
3.接下來配置logger
指定哪些類進(jìn)行何種輸出,這個(gè)比較簡(jiǎn)單,可以直接看栗子:
<?xml version="1.0" encoding="UTF-8"?> <Configuration monitorInterval="1" status="ERROR" strict="true" name="LogConfig"> <Properties> <Property name="logbasedir">e:/log</Property> <Property name="log.layout">%d %-5p %t (%c:%L) - %m%n</Property> </Properties> <--此處使用了兩種類型的appender,RollingFile為滾動(dòng)類型,滿足策略條件后會(huì)新建文件夾記錄 --> <Appenders> <Appender type="Console" name="STDOUT"> <Target>SYSTEM_OUT</Target> <Layout type="PatternLayout" pattern="${log.layout}"/> </Appender> <Appender type="RollingFile" name="FILE" fileName="${logbasedir}/jutap-${sys:APPNAME}.log" filePattern = "${logbasedir}/jutap-${sys:APPNAME}-%d{yyyy-MM-dd}.%i.log"> <Policies> <TimeBasedTriggeringPolicy /> <SizeBasedTriggeringPolicy size="100 MB"/> </Policies> <Layout type="PatternLayout"> <Charset>GBK</Charset> <Pattern>${log.layout}</Pattern> </Layout> </Appender> <Appender type="RollingFile" name="ExceptionLog" fileName="${logbasedir}/exception-${sys:APPNAME}.log" filePattern = "${logbasedir}/exception-${sys:APPNAME}-%d{yyyy-MM-dd}.%i.log"> <Policies> <TimeBasedTriggeringPolicy /> <SizeBasedTriggeringPolicy size="100 MB"/> </Policies> <Layout type="PatternLayout"> <Charset>GBK</Charset> <Pattern>${log.layout}</Pattern> </Layout> </Appender> </Appenders> <Loggers> <Logger name="exception" level="error" additivity="false"> <AppenderRef ref="ExceptionLog"/> </Logger> <Root level="info"> <AppenderRef ref="STDOUT"/> <AppenderRef ref="FILE"/> </Root> <Logger name="com.garfield.learn" level="debug"/> <Logger name="com.garfield.learnp" level="info"/> </Loggers> </Configuration>
到此,相信大家對(duì)“怎么使用log4j2自定義配置文件位置和文件名”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。