鉴于2021年末爆发的lo4j2的jndi漏洞,开始排查公司项目使用log日志框架情况,之前老项目有log4j1的使用,为了针对log4j2进行升级,了解整理下 log4j1 跟log4j2的区别点。
    
    
    log4j 1 的maven引用:
   
<!-- https://mvnrepository.com/artifact/log4j/log4j -->  
<dependency>  
 <groupId>log4j</groupId>  
 <artifactId>log4j</artifactId>  
 <version>1.2.17</version>  
</dependency>
    
    
    log4j2 的maven 可以使用的3个引用(log4j-core,log4j-web,log4j-api),版本号一般一致:
   
<!-- https://mvnrepository.com/artifact/org.apache.logging.log4j/log4j-core -->  
<dependency>  
 <groupId>org.apache.logging.log4j</groupId>  
 <artifactId>log4j-core</artifactId>  
 <version>2.15.0</version>  
</dependency>
    
    
    区别点:
   
- 
 goroupId
 
 :log4j1只有log4j一个单词
 
 log4j
 
 。log4j2 更长,含有apache单词,
 
 org.apache.logging.log4j
 
 。
- 
 artifactId
 
 : log4j1只有一个
 
 log4j1
 
 。log4j2一般使用至少需要引入
 
 log4j-core/api
 
 2个jar
- 
 版本号
 
 :log4j1 都是 1.xx版本开头。log6j2都是 2.xx版本开头
- 
 默认加载的配置文件名
 
 :log4j1的的配置文件默认是log4j开头。log4j2的配置文件默认是log4j2开头。
log4j2配置文件介绍:支持的格式xml/properties/json/yaml ,以及默认加载配置文件名的优先级[https://logging.apache.org/log4j/2.x/manual/configuration.html#Architecture](https://logging.apache.org/log4j/2.x/manual/configuration.html#Architecture
ps:吐槽。百度搜索好多帖子的log4j2还是老版本情况,说不能使用properties的配置文件。其实早可以支持了。不过之前了解到,刚开始log4j2支持propertis的时候,支持还不是很好,不了解现在properties的稳定性如何了,没有去调研,个人还是推荐使用xml稳妥点。
 
