1 . 概述

1.1  日志框架实现

  • log4j是apache实现的一个开源日志组件;
  • logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现;
  • log4j2是log4j 1.x和logback的改进版,据说采用了一些新技术(无锁异步、等等),使得日志的吞吐量、性能比log4j 1.x提高10倍,并解决了一些死锁的bug,而且配置更加简单灵活,官网地址: http://logging.apache.org/log4j/2.x/manual/configuration.html

1.2  日志接口

  slf4j是对所有日志框架制定的一种规范、标准、接口,并不是一个框架的具体的实现,需要和具体的日志框架实现配合使用(如log4j、logback)。

  使用日志接口便于更换为其他日志框架。

  

2. 使用log4j2

使用maven配置log4j2,pom.xml中引入log4j-api 和 log4j-core即可。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>tdtech.practice</groupId>
<artifactId>achitechture</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<log4j.version>2.8.2</log4j.version>
</properties> <dependencies>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j.version}</version>
</dependency> </dependencies>
</project>

java代码示例:

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; public class LogUtil {
   //引入的是log4j自身的包
static Logger log = LogManager.getLogger(); public static void main(String[] args) {
String param1 = "string1";
String param2 = "string2"; log.error("--占位符的方式拼接效率更高-- {} -- {}", param1, param2);
}
} output:
00:10:12.063 [main] ERROR eagle.log.LogUtil - --占位符的方式拼接效率更高-- string1 -- string2

 3. 使用slf4j+log4j2接口

pom.xml中除了引入上述log4j2的包,还需引入slf4j的包:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>tdtech.practice</groupId>
<artifactId>achitechture</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<slf4j.version>1.7.25</slf4j.version>
<log4j.version>2.8.2</log4j.version>
</properties> <dependencies>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>${log4j.version}</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>${log4j.version}</version>
</dependency> <!-- slf4j核心包-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${slf4j.version}</version>
</dependency> <dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${slf4j.version}</version>
<scope>runtime</scope>
</dependency> <!--slf4j绑定log4j实现-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>${log4j.version}</version>
</dependency> </dependencies>
</project>

java代码示例:

package eagle.log;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory; public class LogUtil {
//引入的是slf4j接口的包
static Logger log = LoggerFactory.getLogger(LogUtil.class); public static void main(String[] args) {
String param1 = "string1";
String param2 = "string2"; log.error("--占位符的方式拼接效率更高-- {} -- {}", param1, param2);
}
}

4. log4j2的配置

classpath下添加log4j2.xml,示例:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO" monitorInterval="300">
<Appenders>
<Console name="console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%t] [%file:%line] - %msg%n"/>
</Console> <RollingRandomAccessFile name="gatekeeperFile"
fileName="${bundle:gatekeeper:LOG_HOME}/gatekeeper.log"
filePattern="${bundle:gatekeeper:LOG_HOME}/$${date:yyyy-MM-dd}/gatekeeper-%d{yyyy-MM-dd HH-mm}-%i.log.xz"
immediateFlush="false">
<PatternLayout
pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%t] [%file:%line] - %msg%n"/>
<Policies>
<TimeBasedTriggeringPolicy interval="60"/>
<SizeBasedTriggeringPolicy size="20 MB"/>
</Policies>
<DefaultRolloverStrategy max="10">
<!--
Nested conditions: the inner condition is only evaluated on files
for which the outer conditions are true.
-->
<Delete basePath="${bundle:gatekeeper:LOG_HOME}" maxDepth="2">
<IfFileName glob="*/gatekeeper-*.log.xz">
<IfLastModified age="30d">
</IfLastModified>
</IfFileName>
</Delete>
</DefaultRolloverStrategy>
</RollingRandomAccessFile>
</Appenders> <Loggers>
<AsyncLogger name="org.springframework" level="info" additivity="false" includeLocation="true">
<AppenderRef ref="springFile"/>
</AsyncLogger>
<AsyncLogger name="com.tdtech.eplatform.gatekeeper" level="info" additivity="false" includeLocation="true">
<AppenderRef ref="gatekeeperFile"/>
</AsyncLogger>
<AsyncRoot level="info" includeLocation="false">
<AppenderRef ref="console"/>
</AsyncRoot>
  </Loggers>
</Configuration>

https://blog.csdn.net/NEWCIH/article/details/76216606

最新文章

  1. vim2
  2. Foundation 5 发布!最先进的响应式前端框架
  3. IOS第16天(4,Quartz2D柱状图)
  4. hdu-5929 Basic Data Structure(双端队列+模拟)
  5. 读取properties中的key对应的value
  6. Core Java Volume I — 3.6. Strings
  7. android Camera使用(一)
  8. Linux makefile教程之函数七[转]
  9. python 错误、调试和测试
  10. MYSQL 主从服务器配置工作原理
  11. swift版 关于微信支付的那点事
  12. 微信小程序后台音乐播放注意事项
  13. JavaScript中的数组
  14. hibernate框架学习笔记10:HQL查询详解
  15. MongoDB使用过程中的一些问题
  16. (简单)华为P9plus VIE-AL00的usb调试模式在哪里开启的经验
  17. impdp如何杀掉job
  18. recyclerView插入(add)和删除(remove)item后,item错乱,重复,覆盖在原recyclerView上
  19. flannel
  20. R 的内部机制

热门文章

  1. ubontu 16 下的 pylon5 安装
  2. mysql 触发器实现级联删除有外键的多张表
  3. Hive HA基本原理
  4. The linux command 之进程
  5. window.onload=function(){};
  6. python 使用字符串
  7. 阿里云SaaS加速器“宜搭”发布宜搭Plus提升6倍研发效率
  8. Divide by Zero 2018 and Codeforces Round #474 (Div. 1 + Div. 2, combined)G - Bandit Blues
  9. 关于css布局的定位问题
  10. hdu多校第四场1001 (hdu6614) AND Minimum Spanning Tree 签到