Log配置教程及框架性能比较是什么

发布时间:2021-10-26 10:13:42 作者:iii
来源:亿速云 阅读:167

本篇内容介绍了“Log配置教程及框架性能比较是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、摘要

不管是使用何种编程语言,何种框架,日志输出几乎无处不再,也是任何商业软件中必不可少的一部分。

总结起来,日志的用途大致可以归纳成以下三种:

问题追踪:通过日志不仅仅包括我们程序的一些bug,也可以在安装配置时,通过日志可以发现问题。

状态监控:通过实时分析日志,可以监控系统的运行状态,做到早发现问题、早处理问题。

安全审计:审计主要体现在安全上,通过对日志进行分析,可以发现是否存在非授权的操作。

以 Java 编程语言为例,打印日志的方式有很多,例如通过System.out.print()方法将关键信息输出到控制台,也可以通过 JDK  自带的日志Logger类输出,虽然 JDK  从1.4开始支持日志输出,但是功能单一,无法更好的满足商业要求,于是诞生了很多第三方日志库,像我们所熟悉的主流框架log4j、log4j2、logback等,提供的  API 功能都远胜 JDK 提供的Logger。

二、Log4j

2.1、介绍

Log4j 是一种非常流行的日志框架,由Ceki Gülcü首创,之后将其开源贡献给 Apache 软件基金会。

Log4j 有三个主要的组件:Loggers(记录器),Appenders  (输出源)和Layouts(布局)。这里可简单理解为日志类别、日志要输出的地方和日志以何种形式输出。

综合使用这三个组件可以轻松地记录信息的类型和级别,并可以在运行时控制日志输出的样式和位置。

Log4j 的架构大致如下:

Log配置教程及框架性能比较是什么

当我们使用 Log4j 输出一条日志时,Log4j 自动通过不同的Appender(输出源)把同一条日志输出到不同的目的地。例如:

在输出日志的过程中,通过Filter来过滤哪些log需要被输出,哪些log不需要被输出。

在Loggers(记录器)组件中,级别分五种:DEBUG、INFO、WARN、ERROR和FATAL。

这五个级别是有顺序的,DEBUG < INFO < WARN < ERROR <  FATAL,分别用来指定这条日志信息的重要程度,明白这一点很重要,Log4j有一个规则:只输出级别不低于设定级别的日志信息。

假设Loggers级别设定为INFO,则INFO、WARN、ERROR和FATAL级别的日志信息都会输出,而级别比INFO低的DEBUG则不会输出。

最后,通过Layout来格式化日志信息,例如,自动添加日期、时间、方法名称等信息。

具体输出样式配置,可以参考如下内容Log4j2 - Layouts布局介绍

2.2、项目应用

以 Java 项目为例,在 Maven 的pom.xml中添加如下依赖!

2.2.1、添加 maven 依赖

<dependencies>     <dependency>         <groupId>org.slf4j</groupId>         <artifactId>slf4j-api</artifactId>         <version>1.6.6</version>     </dependency>     <dependency>         <groupId>org.slf4j</groupId>         <artifactId>slf4j-log4j12</artifactId>         <version>1.6.6</version>     </dependency>     <dependency>         <groupId>log4j</groupId>         <artifactId>log4j</artifactId>         <version>1.2.17</version>     </dependency> </dependencies>

2.2.2、创建log4j配置

在实际应用中,要使Log4j在系统中运行须事先设定配置文件。

配置文件实际上也就是对Logger、Appender及Layout进行相应设定。

Log4j支持两种配置文件格式,一种是XML格式的文件,一种是properties属性文件,二选一。

创建一个log4j.xml或者log4j.properties,将其放入项目根目录下。

1、XML格式

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">     <!-- 控制台输出配置 -->     <appender name="console" class="org.apache.log4j.ConsoleAppender">         <!-- 目标为控制台 -->         <param name="Target" value="System.out" />         <layout class="org.apache.log4j.PatternLayout">             <!-- 输出格式 -->             <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %l %m%n" />         </layout>     </appender>     <!-- 文件输出配置 -->     <appender name="log_file" class="org.apache.log4j.DailyRollingFileAppender">         <!-- 目标为文件 -->         <param name="File" value="/logs/log/file.log" />         <!-- 向文件追加输出 -->         <param name="Append" value="true" />         <!-- 每个小时生成一个log -->         <param name="DatePattern" value="'.'yyyy-MM-dd-HH" />         <layout class="org.apache.log4j.PatternLayout">             <!-- 输出格式 -->             <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %l %m%n" />         </layout>     </appender>     <!-- Application Loggers -->     <logger name="org.example">         <level value="info" />     </logger>     <!-- 根目录 -->     <!-- Root Logger -->     <root>         <priority value="info" />         <appender-ref ref="console" />         <appender-ref ref="log_file" />     </root> </log4j:configuration>

2、XML格式

log4j.rootLogger=INFO,M,C,E log4j.additivity.monitorLogger=false  # INFO级别文件输出配置 log4j.appender.M=org.apache.log4j.DailyRollingFileAppender log4j.appender.M.File=/logs/info.log log4j.appender.M.ImmediateFlush=false log4j.appender.M.BufferedIO=true log4j.appender.M.BufferSize=16384 log4j.appender.M.Append=true log4j.appender.M.Threshold=INFO log4j.appender.M.DatePattern='.'yyyy-MM-dd log4j.appender.M.layout=org.apache.log4j.PatternLayout log4j.appender.M.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} %p %l %m %n  # ERROR级别文件输出配置 log4j.appender.E=org.apache.log4j.DailyRollingFileAppender log4j.appender.E.File=/logs/error.log log4j.appender.E.ImmediateFlush=true log4j.appender.E.Append=true log4j.appender.E.Threshold=ERROR log4j.appender.E.DatePattern='.'yyyy-MM-dd log4j.appender.E.layout=org.apache.log4j.PatternLayout log4j.appender.E.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} %p %l %m %n  # 控制台输出配置 log4j.appender.C=org.apache.log4j.ConsoleAppender log4j.appender.C.Threshold=INFO log4j.appender.C.layout=org.apache.log4j.PatternLayout log4j.appender.C.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %l %m %n

2.2.3、log4j使用

在需要打印日志的类中,引入Logger类,在需要的地方打印即可!

package org.example.log4j.service; import org.slf4j.Logger; import org.slf4j.LoggerFactory;  public class LogPrintUtil {     /**log静态常量*/     private static final Logger logger = LoggerFactory.getLogger(LogPrintUtil.class);     public static void main(String[] args){             logger.info("info信息");             logger.warn("warn信息");             logger.error("error信息");     } }

当然你还可以这样写

if(logger.isInfoEnabled()) {     logger.info("info信息"); } if(logger.isWarnEnabled()) {     logger.warn("warn信息"); }

2.2.4、isInfoEnabled()有何作用呢?

简单来说,在某些场景下,用isInfoEnabled()方法判断下是能提升性能的!

例如我们打印这段内容logger.info("User:" + userId + appId),程序在打印这行代码时,先对内容("User:" +  userId + appId)进行字符串拼接,然后再输出。

如果当前配置文件中日志输出级别是info,是直接输出的,当日志输出级别是error时,logger.info()的内容时不输出的,但是我们却进行了字符串拼接,如果加上if(logger.isInfoEnabled())进行一次判定,logger.info()就不会执行,从而更好的提升性能,这个尤其是在高并发和复杂log打印情况下提升非常显著。

另外,ERROR及其以上级别的log信息是一定会被输出的,所以只有logger.isDebugEnabled、logger.isInfoEnabled和logger.isWarnEnabled()方法,而没有logger.isErrorEnabled方法。

三、Log4j2

3.1、介绍

log4j2 是 log4j 1.x 的升级版,参考了 logback  的一些优秀的设计,并且修复了一些问题,因此带来了一些重大的提升,主要特点有:

Log配置教程及框架性能比较是什么

3.2、项目应用

3.2.1、添加 maven 依赖

<dependencies>     <!-- slf4j核心包 -->     <dependency>         <groupId>org.slf4j</groupId>         <artifactId>slf4j-api</artifactId>         <version>1.7.13</version>     </dependency>     <!--用于与common-log保持桥接 -->     <dependency>         <groupId>org.slf4j</groupId>         <artifactId>jcl-over-slf4j</artifactId>         <version>1.7.13</version>         <scope>runtime</scope>     </dependency>     <!--核心log4j2jar包 -->     <dependency>         <groupId>org.apache.logging.log4j</groupId>         <artifactId>log4j-api</artifactId>         <version>2.4.1</version>     </dependency>     <dependency>         <groupId>org.apache.logging.log4j</groupId>         <artifactId>log4j-core</artifactId>         <version>2.4.1</version>     </dependency>     <!--用于与slf4j保持桥接 -->     <dependency>         <groupId>org.apache.logging.log4j</groupId>         <artifactId>log4j-slf4j-impl</artifactId>         <version>2.4.1</version>     </dependency>     <!--需要使用log4j2的AsyncLogger需要包含disruptor -->     <dependency>         <groupId>com.lmax</groupId>         <artifactId>disruptor</artifactId>         <version>3.2.0</version>     </dependency> </dependencies>

3.2.2、创建log4j2配置

在项目的根目录下创建一个log4j2.xml的文件,与log4j相比,log4j2的异步输出日志性能非常强劲,配置如下:

1、同步输出日志

<?xml version="1.0" encoding="UTF-8"?> <!-- status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时。  注:本配置文件的目标是将不同级别的日志输出到不同文件,最大1MB一个文件,      文件数据达到最大值时,旧数据会被压缩并放进指定文件夹 ,最多存放20个文件--> <Configuration status="error">     <!-- 配置日志文件输出目录,此配置将日志输出到根目录下的指定文件夹 -->     <Properties>         <Property name="fileDir">/logs/log4j2</Property>         <Property name="fileHistory">/logs/log4j2/history</Property>     </Properties>     <Appenders>         <!-- 优先级从高到低分别是 OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL -->         <!-- 单词解释:Match:匹配 DENY:拒绝 Mismatch:不匹配 ACCEPT:接受 -->         <!-- DENY,日志将立即被抛弃不再经过其他过滤器;NEUTRAL,有序列表里的下个过滤器过接着处理日志;ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->         <!--输出日志的格式         %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间         %t 输出当前线程名称         %-5level 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0         %logger 输出logger名称,因为Root Logger没有名称,所以没有输出         %msg 日志文本         %n 换行         其他常用的占位符有:         %F 输出所在的类文件名,如Client.java         %L 输出行号         %M 输出所在方法名         %l  输出语句所在的行数, 包括类名、方法名、文件名、行数          -->         <!--这个输出控制台的配置,这里输出all信息到System.out -->         <console name="Console" target="SYSTEM_OUT">             <!-- 输出日志的格式 -->             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />         </console>         <!--这个输出文件的配置,这里输出info信息到junbao_info.log -->         <RollingFile name="RollingFileInfo" fileName="${fileDir}/info.log" filePattern="${fileHistory}/info/%d{yyyy-MM-dd}-%i.log">             <!-- 此Filter意思是,只输出info级别的数据 DENY,日志将立即被抛弃不再经过其他过滤器;NEUTRAL,有序列表里的下个过滤器过接着处理日志;                      ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->             <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>             <!-- 如果启用此配置,则日志会按文件名生成新文件, 即如果filePattern配置的日期格式为 %d{yyyy-MM-dd HH}                      ,则每小时生成一个压缩文件, 如果filePattern配置的日期格式为 %d{yyyy-MM-dd} ,则天生成一个压缩文件,默认为1 -->                 <TimeBasedTriggeringPolicy />                 <!-- 每个日志文件最大1MB,超过1MB生产新的文件 ; -->                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>              <!--文件夹下最多的文件个数-->               <DefaultRolloverStrategy max="20" />         </RollingFile>         <RollingFile name="RollingFileWarn" fileName="${fileDir}/warn.log" filePattern="${fileHistory}/warn/%d{yyyy-MM-dd}-%i.log">             <ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>                 <TimeBasedTriggeringPolicy />                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>             <DefaultRolloverStrategy max="20" />         </RollingFile>         <RollingFile name="RollingFileError" fileName="${fileDir}/error.log" filePattern="${fileHistory}/error/%d{yyyy-MM-dd}-%i.log">             <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>                 <TimeBasedTriggeringPolicy />                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>             <DefaultRolloverStrategy max="20" />         </RollingFile>     </Appenders>     <!--然后定义logger,只有定义了logger并引入的appender,appender才会生效 -->     <Loggers>         <!--全异步输出info级以上的日志信息-->          <!-- <asyncRoot level="info" includeLocation="true">             <appender-ref ref="Console" />             <appender-ref ref="RollingFileInfo" />         </asyncRoot> -->         <!--同步输出info级以上的日志信息-->          <root level="info" includeLocation="true">             <appender-ref ref="Console" />         </root>     </Loggers> </Configuration>

2、异步输出日志

<?xml version="1.0" encoding="UTF-8"?> <!-- status : 这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时。  注:本配置文件的目标是将不同级别的日志输出到不同文件,最大1MB一个文件,      文件数据达到最大值时,旧数据会被压缩并放进指定文件夹 ,最多存放20个文件--> <Configuration status="error">     <!-- 配置日志文件输出目录,此配置将日志输出到根目录下的指定文件夹 -->     <Properties>         <Property name="fileDir">/logs/log4j2</Property>         <Property name="fileHistory">/logs/log4j2/history</Property>     </Properties>     <Appenders>         <!-- 优先级从高到低分别是 OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL -->         <!-- 单词解释:Match:匹配 DENY:拒绝 Mismatch:不匹配 ACCEPT:接受 -->         <!-- DENY,日志将立即被抛弃不再经过其他过滤器;NEUTRAL,有序列表里的下个过滤器过接着处理日志;ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->         <!--输出日志的格式         %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间         %t 输出当前线程名称         %-5level 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0         %logger 输出logger名称,因为Root Logger没有名称,所以没有输出         %msg 日志文本         %n 换行         其他常用的占位符有:         %F 输出所在的类文件名,如Client.java         %L 输出行号         %M 输出所在方法名         %l  输出语句所在的行数, 包括类名、方法名、文件名、行数          -->         <!--这个输出控制台的配置,这里输出all信息到System.out -->         <console name="Console" target="SYSTEM_OUT">             <!-- 输出日志的格式 -->             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />         </console>         <!--这个输出文件的配置,这里输出info信息到junbao_info.log -->         <RollingFile name="RollingFileInfo" fileName="${fileDir}/info.log" filePattern="${fileHistory}/info/%d{yyyy-MM-dd}-%i.log">             <!-- 此Filter意思是,只输出info级别的数据 DENY,日志将立即被抛弃不再经过其他过滤器;NEUTRAL,有序列表里的下个过滤器过接着处理日志;                      ACCEPT,日志会被立即处理,不再经过剩余过滤器。 -->             <ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>             <!-- 如果启用此配置,则日志会按文件名生成新文件, 即如果filePattern配置的日期格式为 %d{yyyy-MM-dd HH}                      ,则每小时生成一个压缩文件, 如果filePattern配置的日期格式为 %d{yyyy-MM-dd} ,则天生成一个压缩文件,默认为1 -->                 <TimeBasedTriggeringPolicy />                 <!-- 每个日志文件最大1MB,超过1MB生产新的文件 ; -->                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>              <!--文件夹下最多的文件个数-->               <DefaultRolloverStrategy max="20" />         </RollingFile>         <RollingFile name="RollingFileWarn" fileName="${fileDir}/warn.log" filePattern="${fileHistory}/warn/%d{yyyy-MM-dd}-%i.log">             <ThresholdFilter level="warn" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>                 <TimeBasedTriggeringPolicy />                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>             <DefaultRolloverStrategy max="20" />         </RollingFile>         <RollingFile name="RollingFileError" fileName="${fileDir}/error.log" filePattern="${fileHistory}/error/%d{yyyy-MM-dd}-%i.log">             <ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY" />             <PatternLayout charset="UTF-8" pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %l %msg%n" />             <Policies>                 <TimeBasedTriggeringPolicy />                 <SizeBasedTriggeringPolicy size="100MB" />             </Policies>             <DefaultRolloverStrategy max="20" />         </RollingFile>     </Appenders>     <!--然后定义logger,只有定义了logger并引入的appender,appender才会生效 -->     <Loggers>         <!--全异步输出info级以上的日志信息-->          <asyncRoot level="info" includeLocation="true">             <appender-ref ref="Console" />             <appender-ref ref="RollingFileInfo" />         </asyncRoot>         <!--同步输出info级以上的日志信息-->          <!-- <root level="info" includeLocation="true">             <appender-ref ref="Console" />         </root> -->     </Loggers> </Configuration>

详细 API 可以参考官方网站!

3.2.3、log4j2使用

与 log4j 类似,直接在需要位置打印日志即可

package org.example.log4j.service; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class LogPrintUtil {     /**log静态常量*/     private static final Logger logger = LoggerFactory.getLogger(LogPrintUtil.class);     public static void main(String[] args){             logger.info("info信息");             logger.warn("warn信息");             logger.error("error信息");     } }

四、Logback

4.1、介绍

Logback 也是用 java 编写一款非常热门的日志开源框架,由 log4j 创始人写的,性能比 log4j 要好!

logback 主要分为3个模块:

4.2、项目应用

4.2.1、添加 maven 依赖

<!--这个依赖直接包含了 logback-core 以及 slf4j-api的依赖--> <dependency>     <groupId>ch.qos.logback</groupId>     <artifactId>logback-classic</artifactId>     <version>1.2.3</version> </dependency> <!-- 支持在xml中写判断标签 --> <dependency>     <groupId>org.codehaus.janino</groupId>     <artifactId>janino</artifactId>     <version>2.7.8</version> </dependency>

4.2.2、创建logback配置文件

1、配置说明

logback在启动的时候,会按照下面的顺序加载配置文件:

上面的顺序表示优先级,使用java  -D配置的优先级最高,只要获取到配置后就不会再执行下面的流程。相关代码可以看ContextInitializer#autoConfig()方法。

2、同步输出日志

<?xml version="1.0" encoding="UTF-8"?> <!-- scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。      debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。 --> <configuration scan="true" scanPeriod="60 seconds" debug="false">     <!-- 运行环境,dev:开发,test:测试,pre:预生产,pro:生产 -->     <property name="system_host" value="dev" />     <property file="system.properties" />     <!-- 上下文变量设置,用来定义变量值,其中name的值是变量的名称,value的值时变量定义的值。 通过<property>定义的值会被插入到logger上下文中。定义变量后,可以使“${}”来使用变量。 -->     <property name="CONTEXT_NAME" value="logback-test" />     <!-- 日志文件存放路径设置,绝对路径 -->     <property name="logs.dir" value="/opt/logs" />     <!-- 日志文件存放路径设置,tomcat路径 -->     <property name="logs.dir" value="${catalina.base}/logs" />     <!-- 定义日志文件 相对输入位置 -->       <property name="log_dir" value="log" />     <!-- 日志输出格式设置 -->     <!--      %d{yyyy-MM-dd HH:mm:ss} [%level] - %msg%n       Logger: %logger       Class: %class       File: %file       Caller: %caller       Line: %line       Message: %m       Method: %M       Relative: %relative       Thread: %thread       Exception: %ex       xException: %xEx       nopException: %nopex       rException: %rEx       Marker: %marker       newline:%n     -->     <property name="CUSTOM_LOG_PATTERN"         value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{90} - %msg%n" />     <!-- 上下文名称:<contextName>, 每个logger都关联到logger上下文, 默认上下文名称为“default”。但可以使用<contextName>设置成其他名字,用于区分不同应用程序的记录。          一旦设置,不能修改。 -->     <contextName>${CONTEXT_NAME}</contextName>     <!-- <appender>是<configuration>的子节点,是负责写日志的组件。 有两个必要属性name和class。name指定appender名称,          class指定appender的实现类。 -->     <appender name="console" class="ch.qos.logback.core.ConsoleAppender">         <!-- 对日志进行格式化。 -->         <encoder>             <pattern>${CUSTOM_LOG_PATTERN}</pattern>             <charset>UTF-8</charset>         </encoder>     </appender>     <appender name="file"         class="ch.qos.logback.core.rolling.RollingFileAppender">         <!-- 按天来回滚,如果需要按小时来回滚,则设置为{yyyy-MM-dd_HH} -->         <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">             <fileNamePattern>log/testC.%d{yyyy-MM-dd}.%i.log</fileNamePattern>             <!-- 如果按天来回滚,则最大保存时间为30天,30天之前的都将被清理掉 -->             <maxHistory>30</maxHistory>             <!-- 按时间回滚的同时,按文件大小来回滚 -->             <timeBasedFileNamingAndTriggeringPolicy                 class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">                 <maxFileSize>100MB</maxFileSize>             </timeBasedFileNamingAndTriggeringPolicy>         </rollingPolicy>         <!-- 过滤器,只记录WARN级别的日志 -->         <!-- 果日志级别等于配置级别,过滤器会根据onMath 和 onMismatch接收或拒绝日志。 -->         <filter class="ch.qos.logback.classic.filter.LevelFilter">             <!-- 设置过滤级别 -->             <level>WARN</level>             <!-- 用于配置符合过滤条件的操作 -->             <onMatch>ACCEPT</onMatch>             <!-- 用于配置不符合过滤条件的操作 -->             <onMismatch>DENY</onMismatch>         </filter>         <!-- 日志输出格式 -->         <encoder>             <pattern>${CUSTOM_LOG_PATTERN}</pattern>             <charset>UTF-8</charset>         </encoder>     </appender>       <appender name="log_file"         class="ch.qos.logback.core.rolling.RollingFileAppender">         <!-- 被写入的文件名,可以是相对目录,也可以是绝对目录,如果上级目录不存在会自动创建,没有默认值。 -->         <file>${logs.dir}/logback-test.log</file>         <!-- 按照固定窗口模式生成日志文件,当文件大于20MB时,生成新的日志文件。窗口大小是1到3,当保存了3个归档文件后,将覆盖最早的日志 -->         <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">             <!-- 必须包含“%i”例如,假设最小值和最大值分别为1和2,命名模式为 mylog%i.log,会产生归档文件mylog1.log和mylog2.log。还可以指定文件压缩选项,例如,mylog%i.log.gz                  或者 没有log%i.log.zip -->             <FileNamePattern>${logs.dir}/logback-test.%i.log</FileNamePattern>             <!-- 窗口索引最小值 -->             <minIndex>1</minIndex>             <!-- 窗口索引最大值 -->             <maxIndex>3</maxIndex>         </rollingPolicy>         <!-- 日志级别过滤器 -->         <filter class="ch.qos.logback.classic.filter.LevelFilter">             <!-- 日志级别过滤器 -->             <level>INFO</level>             <!-- 符合要求的日志级别,过滤,ACCEPT:接受 -->             <onMatch>ACCEPT</onMatch>             <!-- 不符合要求的日志级别,过滤,DENY:拒绝 -->             <onMismatch>DENY</onMismatch>         </filter>         <!-- 激活滚动的条件。 -->         <triggeringPolicy             class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">             <!-- 活动文件的大小,默认值是10MB -->             <maxFileSize>30MB</maxFileSize>         </triggeringPolicy>         <!-- 对记录事件进行格式化。 -->         <encoder>             <pattern>${CUSTOM_LOG_PATTERN}</pattern>             <charset>UTF-8</charset>         </encoder>     </appender>       <!-- 异步输出 -->     <appender name="ASYNC_logback" class="ch.qos.logback.classic.AsyncAppender">         <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->         <!-- <discardingThreshold>0</discardingThreshold> -->         <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->         <!-- <queueSize>256</queueSize> -->         <!-- 添加附加的appender,最多只能添加一个 -->         <appender-ref ref="log_file" />     </appender>     <!-- 指定包输出路径 -->     <!-- 用来设置某一个 包 或者具体的某一个 类 的日志打印级别、以及指定<appender>, name:用来指定受此logger约束的某一个包或者具体的某一个类。          level:用来设置打印级别,大小写无关:TRACE, DEBUG, INFO, WARN, ERROR, ALL 和 OFF,还有一个特俗值INHERITED或者同义词NULL,代表强制执行上级的级别。如果未设置此属性,那么当前loger将会继承上级的级别。          additivity:是否向上级logger传递打印信息。默认是true。(这个logger的上级就是上面的root) <logger>可以包含零个或多个<appender-ref>元素,标识这个appender将会添加到这个logger。 -->     <logger name="org.logback.test" level="DEBUG" additivity="true">         <appender-ref ref="stdout" />     </logger>     <!-- 特殊的<logger>元素,是根logger。只有一个level属性,应为已经被命名为"root". level:设置打印级别,大小写无关:TRACE,          DEBUG, INFO, WARN, ERROR, ALL 和 OFF,不能设置为INHERITED或者同义词NULL。默认是DEBUG。 <root>可以包含零个或多个<appender-ref>元素,标识这个appender将会添加到这个loger。 -->     <root>         <level value="WARN" />         <!-- if表达式,需要Janino jar -->         <!-- Janino 2.6.0版本开始,除了janino.jar之外, commons-compiler.jar也需要在类路径中 -->         <if condition='property("system_host").contains("dev")'>             <then>                 <appender-ref ref="stdout" />             </then>         </if>         <appender-ref ref="file" />     </root> </configuration>

注意:logback如果配置要输出行号,性能会明显降低,如果不是必须,建议不要配置!

4.2.3、logback使用

package org.example.logback.service; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class LogPrintUtil {     /**log静态常量*/     private static final Logger logger = LoggerFactory.getLogger(LogPrintUtil.class);     public static void main(String[] args){          logger.info("info信息");             logger.warn("warn信息");             logger.error("error信息");     } }

五、SLF4J桥接

细心的你,会发现上面代码使用时,都使用的是private static final Logger logger =  LoggerFactory.getLogger(LogPrintUtil.class)这个,其中都来自org.slf4j包,SLF4J是啥?有什么作用呢?

SLF4J本身并不输出日志,最大的特色是**:它可以通过适配的方式挂接不同的日志系统,属于一个日志接口**。

如果项目适配到log4j就使用log4j日志库进行输出;如果适配到logback就使用logback日志库进行输出;如果适配到log4j2就使用log4j2日志库进行输出。

这样最大的好处,就是当你想将项目从log4j换成log4j2的时候,只需要在项目pom.xml中进行桥接适配即可,不用修改具体需要打印日志的代码!

六、三大主流日志框架性能比较

介绍了这么多,但是我们还不知道三个日志框架的日志输出性能如何,本文以10000条数据进行打印,比较log4j、log4j2、logback日志的输出时间。

本次测试采用的是本地电脑(win7),每个电脑的配置不一样,测试的结果也不一样,结果是真实的。

Log配置教程及框架性能比较是什么

Log配置教程及框架性能比较是什么

从测试结果上可以看出:

最后需要注意的地方是:log有风险,输出需谨慎!

由于输出log过程需要进行磁盘操作,且log4j为了保证log输出过程的线程安全性而使用同步锁,就使得输出log成为很耗时的操作,所以log信息一定要言简意赅,不要输出一些无用的log。

“Log配置教程及框架性能比较是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

推荐阅读:
  1. Log4j日志记录框架如何配置
  2. Oracle listener log配置与管理

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

log

上一篇:python如何爬取基金股票最新数据并用excel绘制树状图

下一篇:如何用Python爬取各Android市场应用下载量

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》