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配置最全说明

Log4j配置最全说明

Log4j配置最全说明1. log4j 的配置文件Log4j 支持两种配置文件格式,一种是 XML 格式的文件,一种是Java 特性文件 lg4j.properties (键 = 值)。

1.1. log4j configuration scripts in properties formatlg4j.properties 文件作为作为常用的配置文件的方法如下:配置根 LoggerLogger 负责处理日志记录的大部分操作。

其语法为:log4j.rootLogger = [ level ] , appenderName, appenderName, … 其中, level 是日志记录的优先级,分为 OFF 、 FATAL 、 ERROR 、WARN 、 INFO 、 DEBUG 、 ALL 或者自定义的级别。

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

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

比如在这里定义了 INFO 级别,只有等于及高于这个级别的才进行处理,则应用程序中所有 DEBUG 级别的日志信息将不被打印出来。

ALL: 打印所有的日志, OFF :关闭所有的日志输出。

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

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

Appender配置日志信息输出目的地 Appender 负责控制日志记录操作的输出。

其语法为:log4j.appender.appenderName =.of.appender.classlog4j.appender.appenderName.option1 = value1log4j.appender.appenderName.optionN = valueN其中, Log4j 提供的 appender 有以下几种:org.apache.log4j.ConsoleAppender (控制台),org.apache.log4j.FileAppender (文件),org.apache.log4j.DailyRollingFileAppender (每天产生一个日志文件),org.apache.log4j.RollingFileAppender (文件大小到达指定尺寸的时候产生一个新的文件),可通过log4j.appender.R.MaxFileSize=100KB 设置文件大小,还可通过log4j.appender.R.MaxBackupIndex=1 设置为保存一个备份文件。

log4j

log4j
设置日志消息的初始级别 设置日志信息是否立即输出, 默认为true 设置操作类型 System.out 默认值 System.err
FileAppender Threshold ImmediateFlush File
设置日志消息的初始级别 设置日志信息是否立即输出,默认为true 设置输出的文本 默认值是true,新增文件内容是否覆盖原 有内容,false为覆盖
org.apache.log4j.PatternLayout 可以灵活地指定布局模式 ConversionPattern=%m%n :指定怎样格式化指定的消息.
占位符参考log4j API
org.apache.log4j.SimpleLayout
包含日志信息的级别和信息字符串,内 置的简单布局没有提供自定义设置 包含日志产生的时间,线程,类别等等 信息
Append
DailyRollingFileAppender DatePattern的格式符 的格式符 Threshold '.'yyyy-MM
设置日志消息的初始级别 每月
#在配置文件中设置: '.'yyyy-ww 每周 ImmediateFlush 设置日志信息是否立即输出,默认为true #设置为每月输出 log4j.appender.MyAppenderName.DatePattern = '.'yy-MM '.'yyyy-MM-dd 每天 //在程序中使用 设置输出的文本 File //设置为每月输出 '.'yyyy-MM-dd-a 每天两次 myFile. setDatePattern ("'.true,新增文件内容是否覆盖原 '.'yyyy-MM-dd-HH 每小时 有内容,false为覆盖

log4j升级log4j2遇到的问题及解决方式

log4j升级log4j2遇到的问题及解决方式

log4j升级log4j2遇到的问题及解决⽅式⽬录log4j升级log4j2的问题⼀、导⼊包⼆、在src/main/resources下新建⼀个log4j2.xml⽂件升级log4j2遇到的那些坑log4j升级log4j2的问题⼀、导⼊包<!-- log --><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></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-core</artifactId><version>2.8.2</version></dependency><!-- ⽇志桥接包,适配log4j2 --><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-slf4j-impl</artifactId><version>2.8.2</version></dependency>注意:可能有些包需要依赖log4j,但是升级后只有log4j2了,此时会报找不到类的错,如:Caused by: ng.ClassNotFoundException: org.apache.log4j.Logger那么如果这些包没有使⽤slf4接⼝,⽽是写死了必须依赖log4j的话,如果实在不想导⼊log4j的包,那么只能找能代替这个包的⼯具包使⽤了如:<!-- 使⽤该报去掉log4j,后会报上述错误,所以就把这个包换了 --><dependency><groupId>com.github.sgroschupf</groupId><artifactId>zkclient</artifactId><version>0.1</version><exclusions><exclusion><artifactId>log4j</artifactId><groupId>log4j</groupId></exclusion></exclusions></dependency>替换为如下的包,就可以了:<dependency><groupId>com.101tec</groupId><artifactId>zkclient</artifactId><version>0.10</version><exclusions><exclusion><artifactId>log4j</artifactId><groupId>log4j</groupId></exclusion><exclusion><artifactId>slf4j-log4j12</artifactId><groupId>org.slf4j</groupId></exclusion></exclusions></dependency>⼆、在src/main/resources下新建⼀个log4j2.xml⽂件配置如下<?xml version="1.0" encoding="UTF-8" ?><configuration status="ERROR"><Properties><Property name="PATTERN" value="[%d{HH:mm:ss.SSS} %-5level] [%t] %c{3} - %msg%n" /><property name="FILE_PATH" value="/mySoft/logs" /><property name="FILE_SIZE" value="50 MB" /></Properties><Appenders><!-- 控制台⽇志打印 --><Console name="Console" target="SYSTEM_OUT"><PatternLayout pattern="${PATTERN}"/></Console><!-- ⽣产环境⽇志打印 --><!-- fileName表⽰创建的⽇志⽂件名,filePattern表⽰如果⽇志策略按照⽇期与⼤⼩做限定的话,如果⼤⼩超过50m就会按该格式将之前的的⽇志⽂件重命名,并重新创建新的fileName。

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。

log4j2 filepermission的使用

log4j2 filepermission的使用

log4j2 filepermission的使用Log4j2是一个强大的Java日志框架,可以帮助开发人员在应用程序中实现灵活和高效的日志记录。

其中一个重要的功能是文件权限管理,它可以帮助开发人员控制日志文件的访问权限,并保护敏感数据不被非授权人员获取。

文件权限管理在Log4j2中通过使用FilePermissions属性来实现。

FilePermissions属性是一个用于指定文件权限的字符串,它可以设置读、写和执行权限。

下面是一些常用的FilePermissions属性的示例:1. "rw-rw-rw-":所有用户都有读和写的权限,没有执行的权限。

2. "rwxr-x---":所有用户都有读、写和执行的权限,但其他用户没有读、写和执行的权限。

3. "rw-------":只有文件所有者有读和写的权限,其他用户没有任何的权限。

在Log4j2中,可以通过在配置文件中添加<Properties>元素来定义FilePermissions属性的值。

例如:```<Properties><Property name="filePermissions">rw-rw-rw-</Property></Properties>```此外,还可以通过使用系统属性来动态设置FilePermissions属性的值。

例如,可以在程序启动时设置System Property来指定FilePermissions属性的值。

下面是一个设置FilePermissions属性的示例:```javaSystem.setProperty("log4j2.filePermissions", "rw-rw-rw-");```设置FilePermissions属性后,Log4j2会将此属性应用到所有生成的日志文件上。

log4j2RollingRandomAccessFile配置过程

log4j2RollingRandomAccessFile配置过程

log4j2RollingRandomAccessFile配置过程log4j2 RollingRandomAccessFile配置⼀、需求背景1. ⽇志按⼩时压缩成zip⽂件。

2. 仅保存距离当前时间最近24⼩时的历史压缩⽂件。

3. 压缩封存的zip⽂件,按照零点为参考点纠偏。

4. 将com.roadway.acceptor.base.DebugUtils类的⽇志输出到指定⽂件,且不再输出到其他⽂件。

⼆、log4j2 配置实现<?xml version="1.0" encoding="UTF-8"?><Configuration status="INFO" monitorInterval="120"><properties><property name="MSG_LOG_HOME">/data/gpslog</property></properties><Appenders><Console name="Console" target="SYSTEM_OUT"><PatternLayout pattern="%d [%t] %-5p [%c] - %m%n" /></Console><RollingRandomAccessFile name="msgAppender" immediateFlush="true"fileName="${MSG_LOG_HOME}/msg.log"filePattern="${MSG_LOG_HOME}/backup/msg.%d{yyyyMMddHH}.zip"><Filters><ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/></Filters><PatternLayout pattern="%m%n" /><Policies><TimeBasedTriggeringPolicy interval="1" modulate="true"/></Policies><DefaultRolloverStrategy max="24"><Delete basePath="${MSG_LOG_HOME}" maxDepth="2"><IfFileName glob="*/msg.*.zip" /><IfLastModified age="24H" /></Delete></DefaultRolloverStrategy></RollingRandomAccessFile></Appenders><Loggers><AsyncLogger name="com.roadway.DebugUtils" additivity="FALSE" level="INFO"><appender-ref ref="msgAppender" /></AsyncLogger></Loggers></Configuration>三、配置说明1. monitorInterval,博客配置的为120,单位为秒。

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

以前都是把所有日志都输出到一个文件下面,今天有个同事问想把某个包下的日志输出到指定的地方,于是就在网上查了一些资料,总结一下,以免以后用到。

一、log4j是什么?Log4j是一个开源的日志记录组件,其产品已经相当的成熟,且使用非常的广泛。

在工程中以易用,方便等代替了 System.out 等打印语句。

Log4j的目标是:它允许开发人员以任意的精细程度控制哪些日志说明被输出。

通过使用外部的配置文件,可以在运行时配置它。

Log4j的具体在 /log4j/找到它(有使用的文档说明)。

另外,log4j已经被转换成 C, C++, C#, Perl, Python, Ruby, 和 Eiffel 语言。

二、通常我们建立一个log4j.properties文件放在src下,编译之后就生成在../web-inf/class/当然也可以放到其它任何目录,只要该目录被包含到类路径中即可,中定位这个文件,并读入这个文件完成的配置。

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

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

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

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

这五个级别是有顺序的,DEBUG Log4j有一个规则:假设Loggers级别为P,如果在Loggers中发生了一个级别Q比P高,则可以启动,否则屏蔽掉。

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

其语法表示为: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 = valueN4 . Log4j的配置以上是从原理方面说明Log4j的使用方法,在具体Java编程使用Log4j可以参照以下示例:1、建立Logger实例:语法表示:public static Logger getLogger( String name)实际使用:static Logger logger =Logger.getLogger(ServerWithLog4j.class.getName ()) ;2、读取配置文件:获得了Logger的实例之后,接下来将配置Log4j使用环境:语法表示:或者直接放在src下把log4j.properties文件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特性文件做为配置文件的方法具体如下:三、配置根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,意谓着所有的消息都会被立即输出。

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

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

DatePattern='.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。

当然也可以指定按月、周、天、时和分。

即对应的格式如下:1)'.'yyyy-MM: 每月2)'.'yyyy-ww: 每周3)'.'yyyy-MM-dd: 每天4)'.'yyyy-MM-dd-a: 每天两次5)'.'yyyy-MM-dd-HH: 每小时6)'.'yyyy-MM-dd-HH-mm: 每分钟4.RollingFileAppender 选项Threshold=WARN:指定日志消息的输出最低层次。

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

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

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

MaxFileSize=100KB: 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。

MaxBackupIndex=2:指定可以产生的滚动文件的最大数。

实际应用:log4j.appender.A1=org.apache.log4j.ConsoleAppender //这里指定了日志输出的第一个位置A1是控制台ConsoleAppender3、配置日志信息的格式,其语法为:A. yout =yout.class"yout.class" 可以指定下面4个格式中的一个:.apache.log4j.HTMLLayout(以HTML表格形式布局),.apache.log4j.PatternLayout(可以灵活地指定布局模式),.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)1.HTMLLayout 选项LocationInfo=true:默认值是false,输出java文件名称和行号Title=my app file: 默认值是 Log4J Log Messages.2.PatternLayout 选项ConversionPattern=%m%n :指定怎样格式化指定的消息。

相关文档
最新文档