log4j详解

合集下载

log4j文件切分规则

log4j文件切分规则

log4j文件切分规则一、引言log4j是一个Java日志框架,方便开发者记录应用程序的运行日志并进行管理。

在使用log4j时,我们可以通过配置文件来定义日志的输出方式和切分规则。

本文将重点讨论log4j文件切分规则。

二、按文件大小切分在日志文件的切分规则中,按文件大小切分是最常见的一种方式。

通过配置log4j,我们可以设置一个文件的最大大小,当该文件达到最大大小时,log4j会自动将其备份,并创建一个新的日志文件来记录日志。

这种方式可以确保每个日志文件不会过大,方便查阅和管理。

三、按日期切分除了按文件大小切分,log4j还支持按日期切分日志文件。

通过设置切分的时间间隔,log4j会在指定的时间点自动将当前日志文件备份,并创建一个新的日志文件来记录后续的日志信息。

这种方式可以按照日期来管理日志文件,方便按照时间段进行查阅。

四、按文件数量切分除了按文件大小和日期切分,log4j还支持按文件数量切分日志文件。

通过设置切分的文件数量,当日志文件数量达到指定值时,log4j会自动将最早的日志文件备份,并创建一个新的日志文件来记录新的日志信息。

这种方式可以保持日志文件数量的稳定,避免文件过多导致管理困难。

五、动态切分规则在log4j中,我们可以通过配置动态切分规则来灵活地管理日志文件。

例如,我们可以根据业务需求,定义不同的切分规则,如按照不同的模块或日志级别进行切分。

这样可以根据具体的需求来管理日志文件,使日志信息更加有意义和可读性。

六、配置示例下面是一个示例的log4j配置文件,展示了如何设置文件切分规则:```log4j.rootLogger=INFO, filelog4j.appender.file=org.apache.log4j.RollingFileAppenderlog4j.appender.file.File=/path/to/log/file.loglog4j.appender.file.MaxFileSize=10MBlog4j.appender.file.MaxBackupIndex=10yout=org.apache.log4j.PatternLayoutyout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n```在上述配置中,我们定义了一个名为file的appender,它是一个RollingFileAppender。

log4j 删除日志原理

log4j 删除日志原理

log4j删除日志原理详解1. 什么是log4jlog4j是一个Java日志框架,用于记录应用程序的日志信息。

它是Apache软件基金会的一个开源项目,被广泛用于Java应用程序中。

log4j提供了灵活的配置选项,可以将日志输出到不同的目标(如控制台、文件、数据库等),并且可以根据日志级别过滤不同类型的日志信息。

2. log4j的基本原理log4j的基本原理可以归纳为以下几个步骤:步骤1:配置log4j在使用log4j之前,需要先进行配置。

log4j的配置文件通常为log4j.properties或log4j.xml,其中定义了日志输出的目标、格式、级别等信息。

步骤2:引入log4j库在Java应用程序中引入log4j库,以便在代码中使用log4j提供的API进行日志记录。

步骤3:获取Logger对象在代码中通过调用Logger.getLogger()方法获取Logger对象。

每个Logger对象与一个特定的类关联,用于记录该类产生的日志信息。

步骤4:设置日志级别通过调用Logger对象的setLevel()方法设置该Logger对象所记录的日志级别。

只有达到指定级别及以上的日志信息才会被记录。

步骤5:编写日志记录语句在代码中通过调用Logger对象的不同方法(如debug()、info()、warn()、error()等)编写日志记录语句。

根据不同的日志级别,选择合适的方法进行日志记录。

步骤6:输出日志当代码中执行了Logger对象的日志记录方法后,log4j会根据配置文件中的设置,将相应级别的日志信息输出到指定目标(如控制台、文件、数据库等)。

3. log4j删除日志原理在实际应用中,由于业务需求或存储空间限制,我们可能需要定期删除过时的日志信息。

log4j提供了一些机制来实现删除日志的功能。

基于时间戳删除log4j允许我们在配置文件中设置一个时间戳(或日期),当达到这个时间戳后,自动删除该时间之前的所有日志信息。

详解log4j-over-slf...

详解log4j-over-slf...

详解log4j-over-slf...注:下⽂中的“桥接”、“转调”、“绑定”等词基本都是同⼀个概念。

log4j-over-slf4j和slf4j-log4j12是跟java⽇志系统相关的两个jar包,当它们同时出现在classpath下时,就可能会引起堆栈溢出异常。

异常信息⼤致如下(摘⾃slf4j官⽹⽂档):Exception in thread "main" ng.StackOverflowErrorat java.util.Hashtable.containsKey(Hashtable.java:306)at org.apache.log4j.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:36)at org.apache.log4j.LogManager.getLogger(LogManager.java:39)at org.slf4j.impl.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:73)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:249)at org.apache.log4j.Category.<init>(Category.java:53)at org.apache.log4j.Logger..<init>(Logger.java:35)at org.apache.log4j.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:39)at org.apache.log4j.LogManager.getLogger(LogManager.java:39)at org.slf4j.impl.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:73)at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:249)at org.apache.log4j.Category..<init>(Category.java:53)at org.apache.log4j.Logger..<init>(Logger.java:35)at org.apache.log4j.Log4jLoggerFactory.getLogger(Log4jLoggerFactory.java:39)at org.apache.log4j.LogManager.getLogger(LogManager.java:39)subsequent lines omitted...现有⽇志体系分析这个异常出现的具体原因之前,有必要先快速了解⼀下现有的Java⽇志体系。

springlog4j2.xml配置文件详解

springlog4j2.xml配置文件详解

springlog4j2.xml配置⽂件详解⼀、log4j2介绍 log4j 2.x版本不再⽀持像1.x中的.properties后缀的⽂件配置⽅式,2.x版本配置⽂件后缀名只能为".xml",".json"或者".jsn"。

配置⽂件的格式:log2j配置⽂件可以是xml格式的,也可以是json格式的。

配置⽂件的位置:log4j2默认会在classpath⽬录下寻找log4j2.xml、log4j.json、log4j.jsn等名称的⽂件。

系统选择配置⽂件的优先级(从先到后)如下: (1).classpath下的名为log4j2-test.json 或者log4j2-test.jsn的⽂件. (2).classpath下的名为log4j2-test.xml的⽂件. (3).classpath下名为log4j2.json 或者log4j2.jsn的⽂件. (4).classpath下名为log4j2.xml的⽂件. 我们⼀般默认使⽤log4j2.xml进⾏命名。

⼆、配置⽂件节点解析 (1).根节点Configuration有两个属性:status和monitorinterval,有两个⼦节点:Appenders和Loggers(表明可以定义多个Appender和Logger)。

status⽤来指定log4j本⾝的打印⽇志的级别。

monitorinterval⽤于指定log4j⾃动重新配置的监测间隔时间,单位是s,最⼩是5s。

(2).Appenders节点,常见的有三种⼦节点:Console、RollingFile、File。

Console节点⽤来定义输出到控制台的Appender。

name:指定Appender的名字. target:SYSTEM_OUT 或 SYSTEM_ERR,⼀般只设置默认:SYSTEM_OUT。

PatternLayout:输出格式,不设置默认为:%m%n。

log4j2Filter用法详解

log4j2Filter用法详解

log4j2Filter⽤法详解主要说下组合过滤器 CompositeFilter ,⽐较常⽤<Filters>是组合过滤器额标签,它包含的⼦标签是具体的过滤器,这三个具体过滤器分别是⽇志等级过滤器,正则表达式过滤器和时间过滤器。

需要说明的是onMatch和onMismatch可以选择的值及其含义。

可选的值分别是,ACCEPT, DENY, NEUTRAL,ACCEP和DENY⽐较好理解就是接受和拒绝的意思,在使⽤单个过滤器的时候,⼀般就是使⽤这两个值。

但是在组合过滤器中,如果⽤接受ACCEPT的话,⽇志信息就会直接写⼊⽇志⽂件,后续的过滤器不再进⾏过滤。

--- 有点像switch case break; 直接截断了不会往下判断了。

在组合过滤器中,接受使⽤NEUTRAL(中⽴),被第⼀个过滤器接受的⽇志信息,会继续⽤后⾯的过滤器进⾏过滤,只有符合所有过滤器条件的⽇志信息,才会被最终写⼊⽇志⽂件。

--- 也就是层层过滤的意思,要都满⾜条件才能写⼊⽇志例⼦1<!-- 所要过滤的内容必须是⽇志内容详情,前⾯的包名不算 --><Filters><ThresholdFilter level="TRACE" onMatch="NEUTRAL" onMismatch="DENY"/><RegexFilter regex=".* test .*" onMatch="NEUTRAL" onMismatch="DENY"/><TimeFilter start="05:00:00" end="05:30:00" onMatch=" NEUTRAL " onMismatch="DENY"/></Filters>例⼦2 意思是⽇志内存包含 HiveSql 或 hive lines 或 sql_type 或 => 的INFO及其INFO以下级别的⽇志<Filters><ThresholdFilter level="INFO" onMatch="NEUTRAL" onMismatch="DENY"/><RegexFilter regex=".*(HiveSql|hive lines|sql_type).*" onMatch="NEUTRAL" onMismatch="DENY"/><RegexFilter regex=".*=>.*" onMatch="NEUTRAL" onMismatch="DENY"/></Filters>。

第三篇SpringBoot整合log4j2详解

第三篇SpringBoot整合log4j2详解

第三篇SpringBoot整合log4j2详解源代码:提取码:wff0SpringBoot整合Log4j2步骤:1、删除spring-boot-starter-parent默认使⽤spring-boot-starter-logging依赖2、在pom.xml中增加spring-boot-starter-log4j2依赖3、创建log4j2.xml⽂件即可4、执⾏,指定⽬录会⽣成相应的log⽂件1:删除spring-boot-starter-logging见下图,打开pom.xml⽂件最终定位到spring-boot-dependencies⽂件,在此⽂件中将Logging依赖注释掉即可将spring-boot-starter-logging注释后别忙着执⾏或debug会报错:SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".将spring-boot-starter-log4j2依赖添加到pom.xml后就没这个问题了注意:下⾯version版本,2.2.7.RELEASE会失效,可能是版本不匹配,所以使⽤下⾯的版本同截图org.springframework.bootspring-boot-starter-parent2.2.4.RELEASE2:将下⾯依赖添加到pom.xml⽂件中<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-log4j2</artifactId></dependency></dependencies>3:在src.java.main.resources⽬录下创建log4j2.xml⽂件 log4j2.xml⽂件内容如下:<!--⽇志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL --><!--⾃定义命名格式:%d:发⽣时间,%d{yyyy-MM-dd HH:mm:ss,SSS},输出类似:2020-02-20 22:10:28,921%F:输出所在的类⽂件名%t:线程名称%p:⽇志级别%c:⽇志消息所在类名%m:消息内容%M:输出所在函数名%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其⽤到像java servlets这样的多客户多线程的应⽤中。

log4j使用教程详解(怎么使用log4j2)

log4j使⽤教程详解(怎么使⽤log4j2)1. 去官⽅下载log4j 2,导⼊jar包,基本上你只需要导⼊下⾯两个jar包就可以了(xx是乱七⼋糟的版本号):log4j-core-xx.jarlog4j-api-xx.jar2. 导⼊到你的项⽬中:这个就不说了。

3. 开始使⽤:我们知道,要在某个类中使⽤log4j记录⽇志,只需要申明下⾯的成员变量(其实不⼀定要是成员变量,只是为了⽅便调⽤⽽已)复制代码代码如下:private static Logger logger = LogManager.getLogger(MyApp.class.getName());⾥getLogger有⼀个参数指定的是这个logger的名称,这个名称在配置⽂件⾥⾯可是有需要的,这个待会⼉再说。

声明了Logger对象,我们就可以在代码中使⽤他了。

4. ⽇志的级别:我们现在要调⽤logger的⽅法,不过在这个Logger对象中,有很多⽅法,所以要先了解log4j的⽇志级别,log4j规定了默认的⼏个级别:trace<debug<info<warn<error<fatal等。

这⾥要说明⼀下:1)级别之间是包含的关系,意思是如果你设置⽇志级别是trace,则⼤于等于这个级别的⽇志都会输出。

2)基本上默认的级别没多⼤区别,就是⼀个默认的设定。

你可以通过它的API⾃⼰定义级别。

你也可以随意调⽤这些⽅法,不过你要在配置⽂件⾥⾯好好处理了,否则就起不到⽇志的作⽤了,⽽且也不易读,相当于⼀个规范,你要完全定义⼀套也可以,不⽤没多⼤必要。

3)这不同的级别的含义⼤家都很容易理解,这⾥就简单介绍⼀下:trace:是追踪,就是程序推进以下,你就可以写个trace输出,所以trace应该会特别多,不过没关系,我们可以设置最低⽇志级别不让他输出。

debug:调试么,我⼀般就只⽤这个作为最低级别,trace压根不⽤。

tomcat log4j 级别

在Tomcat中,Log4j的日志级别有:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、ALL。

其中,FATAL、ERROR、WARN、INFO、DEBUG是经常使用的级别,它们的优先级从高到低分别是:ERROR、WARN、INFO、DEBUG。

如果定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来,也就是说大于等于INFO级别的日志才会被输出。

这种日志记录的级别具有继承性,子类会记录父类的所有日志级别。

在配置Log4j时,可以使用配置文件(如log4j.properties或log4j.xml)来设定需要的日志级别。

例如,在log4j.properties文件中,可以通过如下设置来定义根节点(root logger)的日志级别为INFO,并关联一个名为Log4jConsole的Appender:
log4j.rootLogger=INFO, Log4jConsole
同时,可以进一步通过配置Appender来设定日志的具体输出方式。

例如,以下配置将控制台输出的日志级别设定为INFO:
log4j.appender.Log4jConsole=org.apache.log4j.ConsoleAppender
log4j.appender.Log4jConsole.Threshold=INFO
以上信息仅供参考,具体的配置方式可能会因实际情况而异。

建议查阅Tomcat和Log4j 的官方文档或手册以获取更准确和详细的信息。

Log4j.properties配置详解

Log4j.properties配置详解转载:⼀、Log4j简介Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局)。

这⾥可简单理解为⽇志类别,⽇志要输出的地⽅和⽇志以何种形式输出。

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

1、LoggersLoggers组件在此系统中被分为五个级别:DEBUG、INFO、WARN、ERROR和FATAL。

这五个级别是有顺序的,DEBUG < INFO < WARN < ERROR < FATAL,分别⽤来指定这条⽇志信息的重要程度,明⽩这⼀点很重要,Log4j有⼀个规则:只输出级别不低于设定级别的⽇志信息,假设Loggers级别设定为INFO,则INFO、WARN、ERROR和FATAL级别的⽇志信息都会输出,⽽级别⽐INFO低的DEBUG 则不会输出。

2、Appenders禁⽤和使⽤⽇志请求只是Log4j的基本功能,Log4j⽇志系统还提供许多强⼤的功能,⽐如允许把⽇志输出到不同的地⽅,如控制台(Console)、⽂件(Files)等,可以根据天数或者⽂件⼤⼩产⽣新的⽂件,可以以流的形式发送到其它地⽅等等。

常使⽤的类如下:org.apache.log4j.ConsoleAppender(控制台)org.apache.log4j.FileAppender(⽂件)org.apache.log4j.DailyRollingFileAppender(每天产⽣⼀个⽇志⽂件)org.apache.log4j.RollingFileAppender(⽂件⼤⼩到达指定尺⼨的时候产⽣⼀个新的⽂件)org.apache.log4j.WriterAppender(将⽇志信息以流格式发送到任意指定的地⽅)配置模式:log4j.appender.appenderName = classNamelog4j.appender.appenderName.Option1 = value1…log4j.appender.appenderName.OptionN = valueN3、Layouts有时⽤户希望根据⾃⼰的喜好格式化⾃⼰的⽇志输出,Log4j可以在Appenders的后⾯附加Layouts来完成这个功能。

log4j 传常数参数

log4j传常数参数概述Log4j是一个广泛使用的日志库,它提供了灵活的日志记录功能。

在Log4j 中,可以通过配置文件或代码中的参数来控制日志记录的行为。

其中,常数参数是一种常用的配置方式,可以在代码中传递常数参数来设置日志记录的格式、输出目标、级别等。

本文将介绍如何使用Log4j传递常数参数。

使用场景在使用Log4j进行日志记录时,有时候需要根据不同的场景设置不同的参数。

例如,在开发不同功能模块时,可能需要设置不同的日志级别、输出目标、格式等。

通过传递常数参数,可以在代码中灵活地调整这些参数,以满足不同模块的需求。

步骤1.引入Log4j相关依赖。

在项目中引入Log4j的依赖库,以便使用Log4j的相关功能。

2.定义常数参数。

在代码中定义常数参数,用于存储需要传递的参数值。

可以使用`@Log4jParameter`注解来标识常数参数。

3.传递常数参数。

在日志记录方法中,使用`@Log4jParameter`注解来传递常数参数的值。

这些参数的值将在日志记录时被替换为实际的值。

4.配置Log4j。

根据需要配置Log4j的日志记录器、输出目标、格式等。

可以使用配置文件或代码中的配置方法来进行配置。

示例代码以下是一个简单的示例代码,展示了如何使用Log4j传递常数参数:```javaimportorg.apache.logging.log4j.LogManager;importorg.apache.logging.log4j.Logger;importorg.apache.logging.log4j.core.config.Configurator;publicclassLogExample{privatestaticfinalLoggerlogger=LogManager.getLogger(LogExample.clas s);//常数参数定义publicstaticfinalStringLOG_LEVEL="INFO";publicstaticfinalStringOUTPUT_TARGET="console";publicstaticfinalStringLOG_FORMAT="%d{yyyy-MM-ddHH:mm:ss}%-5p%c{1}:%L-%m%n";publicstaticvoidmain(String[]args){//配置Log4jConfigurator.configure(LOG_FORMAT);//设置日志格式logger.log(LOG_LEVEL,"这是一条信息日志");//传递常数参数值到日志记录器logger.error("这是一条错误日志");//直接记录常规错误日志,不传递常数参数值到日志记录器}}```注意事项在使用Log4j传递常数参数时,需要注意以下几点:1.常数参数的值应该在代码中提前定义好,以便在日志记录时能够被替换为实际的值。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

log4j详解通常,我们都提供一个名为 log4j.properties的文件,在第一次调用到Log4J时,Log4J会在类路径(../web-inf/class/当然也可以放到其它任何目录,只要该目录被包含到类路径中即可)中定位这个文件,并读入这个文件完成的配置。

这个配置文件告诉Log4J以什么样的格式、把什么样的信息、输出到什么地方。

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

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

下面对三个组件分别进行说明:1、 LoggersLoggers组件在此系统中被分为五个级别:DEBUG、INFO、WARN、ERROR和FATAL。

这五个级别是有顺序的,DEBUG < INFO < WARN < ERROR < FATAL,分别用来指定这条日志信息的重要程度,明白这一点很重要,这里Log4j有一个规则:假设Loggers级别为P,如果在Loggers中发生了一个级别Q比P高,则可以启动,否则屏蔽掉。

假设你定义的级别是info,那么error和warn的日志可以显示而比他低的debug 信息就不显示了。

Java程序举例来说://建立Logger的一个实例,命名为“com.foo”Logger logger = Logger.getLogger("com.foo"); //"com.foo"是实例进行命名,也可以任意//设置logger的级别。

通常不在程序中设置logger的级别。

一般在配置文件中设置。

logger.setLevel();Logger barlogger = Logger.getLogger("com.foo.Bar");//下面这个请求可用,因为WARN >= INFOlogger.warn("Low fuel level.");//下面这个请求不可用,因为DEBUG < INFOlogger.debug("Starting search for nearest gas station.");//命名为“com.foo.bar”的实例barlogger会继承实例“com.foo”的级别。

因此,下面这个请求可用,因为INFO >= INFO("Located nearest gas station.");//下面这个请求不可用,因为DEBUG < INFObarlogger.debug("Exiting gas station search");这里“是否可用”的意思是能否输出Logger信息。

在对Logger实例进行命名时,没有限制,可以取任意自己感兴趣的名字。

一般情况下建议以类的所在位置来命名Logger实例,这是目前来讲比较有效的Logger命名方式。

这样可以使得每个类建立自己的日志信息,便于管理。

比如:static Logger logger =Logger.getLogger(ClientWithLog4j.class.getName());2、Appenders禁用与使用日志请求只是Log4j其中的一个小小的地方,Log4j日志系统允许把日志输出到不同的地方,如控制台(Console)、文件(Files)、根据天数或者文件大小产生新的文件、以流的形式发送到其它地方等等。

其语法表示为:org.apache.log4j.ConsoleAppender(控制台)org.apache.log4j.FileAppender(文件)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)配置时使用方式为:log4j.appender.appenderName =.of.appender.classlog4j.appender.appenderName.option1 = value1…log4j.appender.appenderName.option = valueN这样就为日志的输出提供了相当大的便利。

3、Layouts有时用户希望根据自己的喜好格式化自己的日志输出。

Log4j可以在Appenders的后面附加Layouts来完成这个功能。

Layouts提供了四种日志输出样式,如根据HTML样式、自由指定样式、包含日志级别与信息的样式和包含日志时间、线程、类别等信息的样式等等。

其语法表示为:org.apache.log4j.HTMLLayout(以HTML表格形式布局),org.apache.log4j.PatternLayout(可以灵活地指定布局模式),org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)配置时使用方式为:yout=yout.classyout.option1 = value1…yout.option = valueN>>>> 4 . Log4j的配置 <<<<以上是从原理方面说明Log4j的使用方法,在具体Java编程使用Log4j可以参照以下示例:1、建立Logger实例:语法表示:public static Logger getLogger( String name)实际使用:static Logger logger =Logger.getLogger(ServerWithLog4j.class.getName ()) ;2、读取配置文件:获得了Logger的实例之后,接下来将配置Log4j使用环境:语法表示:BasicConfigurator.configure():自动快速地使用缺省Log4j环境。

PropertyConfigurator.configure(String configFilename):读取使用Java的特性文件编写的配置文件。

DOMConfigurator.configure(String filename):读取XML形式的配置文件。

实际使用:PropertyConfigurator.configure("ServerWithLog4j.properties");3、插入日志信息完成了以上连个步骤以后,下面就可以按日志的不同级别插入到你要记录日志的任何地方了。

语法表示:Logger.debug(Object message);//调试信息(Object message);//一般信息Logger.warn(Object message);//警告信息Logger.error(Object message);//错误信息Logger.fatal(Object message);//致命错误信息实际使用:("ServerSocket before accept: " + server);>>>> 5. 配置过程 <<<<在实际编程时,要使Log4j真正在系统中运行事先还要对配置文件进行定义。

定义步骤就是对Logger、Appender及Layout的分别使用。

Log4j支持两种配置文件格式,一种是XML格式的文件,一种是java properties(key=value)【Java特性文件(键=值)】。

下面我们介绍使用Java 特性文件做为配置文件的方法具体如下:1、配置根Logger,其语法为:log4j.rootLogger = [ level ] , appenderName1, appenderName2, …level : 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。

Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。

通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。

比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。

appenderName:就是指定日志信息输出到哪个地方。

您可以同时指定多个输出目的地。

例如:log4j.rootLogger=info,A1,B2,C32、配置日志信息输出目的地,其语法为:log4j.appender.appenderName =.of.appender.class //".of.appender.class" 可以指定下面五个目的地中的一个:.apache.log4j.ConsoleAppender(控制台).apache.log4j.FileAppender(文件).apache.log4j.DailyRollingFileAppender(每天产生一个日志文件).apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件).apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)1.ConsoleAppender选项Threshold=WARN:指定日志消息的输出最低层次。

ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。

Target=System.err:默认情况下是:System.out,指定输出控制台2.FileAppender选项Threshold=WARN:指定日志消息的输出最低层次。

ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。

File=mylog.txt:指定消息输出到mylog.txt文件。

Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。

3.DailyRollingFileAppender选项Threshold=WARN:指定日志消息的输出最低层次。

ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。

相关文档
最新文档