log4j升级到log4j2


log4j升级到log4j2

1、导入依赖

log4j2应尽量使用同一版本,否则可能出现不兼容的情况



<dependency>
    <groupId>org.apache.logging.log4jgroupId>
    <artifactId>log4j-1.2-apiartifactId>
    <version>2.9.1version>
dependency>
<dependency>
    <groupId>org.apache.logging.log4jgroupId>
    <artifactId>log4j-webartifactId>
    <version>2.9.1version>
dependency>

<dependency>
    <groupId>org.apache.logging.log4jgroupId>
    <artifactId>log4j-coreartifactId>
    <version>2.9.1version>
dependency>

<dependency>
    <groupId>org.apache.logging.log4jgroupId>
    <artifactId>log4j-apiartifactId>
    <version>2.9.1version>
dependency>

 

2、log4j.properties升级为log4j2.properties

log4j2支持log4j2.properties配置文件

status = warn
name = MyApp
?
#指定输出源‘类型’为控制台
appender.console.type = Console
appender.console.name = consoleLogDemo
appender.console.filter.threshold.type = ThresholdFilter
appender.console.filter.threshold.level = debug
appender.console.layout.type = PatternLayout
appender.console.layout.pattern = [%-5p] [%d{yyyy-MM-dd HH:mm:ss}] [%C{1}:%M:%L] %m%n
appender.console.target = System_out
?
appender.rolling.type = RollingFile
appender.rolling.name = fileLogDemo
appender.rolling.filter.threshold.type = ThresholdFilter
appender.rolling.filter.threshold.level = info
appender.rolling.layout.type = PatternLayout
appender.rolling.layout.pattern = [%-5p] [%d{yyyy-MM-dd HH:mm:ss}] [%C{1}:%M:%L] %m%n
appender.rolling.append = true
appender.rolling.fileName =/data/logs/workflow/web.log
appender.rolling.filePattern=/data/logs/wokflow/web.log.%d{yyyy-MM-dd}
appender.rolling.policies.type = Policies
appender.rolling.policies.time.type = TimeBasedTriggeringPolicy
appender.rolling.policies.time.interval = 2
appender.rolling.policies.time.modulate = true
appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
appender.rolling.policies.size.size=100MB
appender.rolling.strategy.type = DefaultRolloverStrategy
appender.rolling.strategy.max = 5
?
?
logger.rolling.name = com.iqiyi
logger.rolling.level = info
logger.rolling.additivity = false
logger.rolling.appenderRef.rolling.ref = fileLogDemo
?
#指明根级日志的级别
rootLogger.level = info
#指定哪些appender输出源是根级日志的输出级别
rootLogger.appenderRef.consolelogdemo.ref = consoleLogDemo
rootLogger.appenderRef.filelogdemo.ref = fileLogDemo

 

参考文档:

[log4j2中的properties配置文件]  http://www.360doc.com/content/18/0628/10/339365_766029208.shtml  [log4j 2.x 版本的 properties 配置]  https://www.cnblogs.com/chensuqian/p/10419218.html  [升级log4j 2.x版本 缓存异步化配置解读]  https://www.iteye.com/blog/zl378837964-2359382  [旧web项目log4j日志升级至log4j2【从servlet2.x版本升级】]  https://blog.csdn.net/leixingbang1989/article/details/86518061 

 

3、log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="error" monitorInterval="30">
    <Properties>
        <Property name="baseDir">logProperty>
    Properties>
    
    <appenders>
        
        <Console name="Console" target="SYSTEM_OUT">
            
            <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
            <PatternLayout pattern="%d %5p %c:%L - %m %throwable{}%n"/>
        Console>
        
        <Async name="ASYNC" bufferSize="262144" includeLocation="true">
            <AppenderRef ref="RollingFile"/>
        Async>
        
        <RollingFile name="RollingFile" fileName="${baseDir}/info.log" filePattern="${baseDir}/info.log.%d{yyyy-MM-dd}">
            
            <PatternLayout pattern="%d %5p %c:%L - %m %throwable{separator( --> )}%n"/>
            
            <TimeBasedTriggeringPolicy interval="1"/>
            <DefaultRolloverStrategy>
                
                <Delete basePath="${baseDir}">
                    <IfFileName glob="info.log.*"/>
                    <IfLastModified age="7d"/>
                Delete>
            DefaultRolloverStrategy>
        RollingFile>
    appenders>
    
    <loggers>
        <root level="INFO">
            <appender-ref ref="Console"/>
            <appender-ref ref="RollingFile"/>
        root>
        
        <logger name="org.hibernate.validator" level="ERROR"/>
    loggers>
configuration>

 

4、修改web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
         version="2.5">
     
    <listener>
        <listener-class>org.apache.logging.log4j.web.Log4jServletContextListenerlistener-class>
    listener>
    <filter>
        <filter-name>log4jServletFilterfilter-name>
        <filter-class>org.apache.logging.log4j.web.Log4jServletFilterfilter-class>
    filter>
    <filter-mapping>
        <filter-name>log4jServletFilterfilter-name>
        <url-pattern>/*url-pattern>
        <dispatcher>REQUESTdispatcher>
        <dispatcher>FORWARDdispatcher>
        <dispatcher>INCLUDEdispatcher>
        <dispatcher>ERRORdispatcher>
    filter-mapping>
    <context-param>
        <param-name>log4jContextNameparam-name>
        <param-value>myApplicationparam-value>
    context-param>
    <context-param>
        <param-name>log4jConfigurationparam-name>
        <param-value>classpath:log4j2.propertiesparam-value>
    context-param>
    

在web.xml中移除旧的log4j.property的配置

 <context-param>
      <param-name>log4jConfigLocationparam-name>
      <param-value>classpath:log4j.propertiesparam-value>
 context-param>

5、log4j2测试

使用的LogManager.getLogger(Object.class)方式获取对象

加入测试类,并运行。如在项目磁盘目录下正常输出日志内容则说明log4j2添加成功:

public class TestLogger {
    private static final Logger log = LoggerFactory.getLogger(TestLogger.class);
    public static void main(String[] args) {
        int number=10;
        log.info("AAAAAAAAAAInfo : number is " + number);
        log.warn("AAAAAAAAAAAAAAAWarning : number is " + number);
        log.debug("AAAAAAAAADebug : number is " + number);
        log.error("AAAAAAAAAAAError : number is " + number);
?
    }
}