java中Log4J使用配置参数的总结
来源:互联网 发布:中国外贸依存度数据 编辑:程序博客网 时间:2024/05/16 01:23
一般使用Log4J时除了应用对应的jar包外还需要配置相应的log4j.properties属性文件,下面将对该文件的配置做一个总结,方便以后回忆。----------一、首先配置根,格式为:log4j.rootLogger=[level],appendername1,appendername2...1、其中level为级别,日志级别从高到低分为:A:off 最高等级,用于关闭所有日志记录。B:fatal 指出每个严重的错误事件将会导致应用程序的退出。C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。D:warm 表明会出现潜在的错误情形。E:info 一般和在粗粒度级别上,强调应用程序的运行全程。F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。G:all 最低等级,用于打开所有日志记录。上面这些级别是定义在org.apache.log4j.Level类中。Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。通过使用日志级别,可以控制应用程序中相应级别日志信息的输出。例如,如果使用b了info级别,则应用程序中所有低于info级别的日志信息(如debug)将不会被打印出来。2、appendername为输出端的名称,可以任意命名,建议输出到控制台可以用syso,调试信息可以为D,错误信息为E这类。----------二、输出端设置1、输出目的地配置,格式如下:log4j.appender.appenderName = 输出的目的地目的地有一下6种a:org.apache.log4j.ConsoleAppender:将日志信息输出到控制台。b:org.apache.log4j.FileAppender:将日志信息输出到一个文件。c:org.apache.log4j.DailyRollingFileAppender:将日志信息输出到一个日志文件,并且按设置的时间输出到一个新的日志文件。d:org.apache.log4j.RollingFileAppender:将日志信息输出到一个日志文件,并且指定文件的尺寸,当文件大小达到指定尺寸时,会自动把文件改名,同时产生一个新的文件。e:org.apache.log4j.WriteAppender:将日志信息以流格式发送到任意指定地方。f::org.apache.log4j.jdbc.JDBCAppender:通过JDBC把日志信息输出到数据库中。2、配置日志信息的格式 log4j.appender.appenderName.layout = 格式 输出格式有一下四种 a:org.apache.log4j.HTMLLayout(以HTML表格形式布局), b:org.apache.log4j.PatternLayout(可以灵活地指定布局模式), c:org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), d:org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)三、一般常用输出端包含的常用属性:控制台选项 -Threshold=DEBUG:指定日志消息的输出最低层次。 -ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。 -Target=System.err(红色):默认情况下是:System.out(黑色),指定输出控制台。FileAppender 选项 -Threshold=DEBUG:指定日志消息的输出最低层次。 -ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。 -File=mylog.txt:指定消息输出到mylog.txt文件。 -Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。 -Encoding = UTF-8:可以指定文件编码格式 DailyRollingFileAppender 选项 -Threshold = WARN:指定日志消息的输出最低层次 -ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出 -File = C:\log4j.log:指定消息输出到C:\log4j.log文件 -Append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容 -DatePattern='.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。还可以按用以下参数: '.'yyyy-MM:每月 '.'yyyy-ww:每周 '.'yyyy-MM-dd:每天 '.'yyyy-MM-dd-a:每天两次 '.'yyyy-MM-dd-HH:每小时 '.'yyyy-MM-dd-HH-mm:每分钟 -Encoding = UTF-8:可以指定文件编码格式RollingFileAppender 选项 Threshold=DEBUG:指定日志消息的输出最低层次。 ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。 File=mylog.txt:指定消息输出到mylog.txt文件。 Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。 MaxFileSize=100KB: 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。 MaxBackupIndex=2:指定可以产生的滚动文件的最大数。 Encoding = UTF-8:可以指定文件编码格式 以下公用的输出格式 log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ss} %c %m%n日志信息格式中几个符号所代表的含义: -X号: X信息输出时左对齐; %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL; %d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss,SSS}; %r: 输出自应用启动到输出该log信息耗费的毫秒数; %c: 输出日志信息所属的类目,通常就是所在类的全名; %t: 输出产生该日志事件的线程名; %l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10); %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中; %%: 输出一个"%"字符; %F: 输出日志消息产生时所在的文件名称; %L: 输出代码中的行号; %m: 输出代码中指定的消息,产生的日志具体信息; %n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行; 可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如: 1) %20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。 2) %-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。 3) %.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。 4) %20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉。例:log4j.rootLogger = debug,stdout,E,I,D
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %-d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File = log/error.log
log4j.appender.E.DatePattern=yyyyMMddHHmmss’.log’
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
log4j.appender.I = org.apache.log4j.RollingFileAppender
log4j.appender.I.File = log/info.log
log4j.appender.I.Append = true
log4j.appender.I.Threshold = INFO
log4j.appender.I.layout = org.apache.log4j.PatternLayout
log4j.appender.I.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
log4j.appender.I.MaxFileSize = 1MB
log4j.appender.I.MaxBackupIndex=20
log4j.appender.D = org.apache.log4j.RollingFileAppender
log4j.appender.D.File = log/debug.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
log4j.appender.D.MaxFileSize = 1MB
log4j.appender.D.MaxBackupIndex=20
- java中Log4J使用配置参数的总结
- log4j的使用配置与参数解析
- log4j的配置参数
- log4j配置 使用总结
- java中log4j的使用
- java中Log4j的使用
- 【java中Log4j的使用】
- Java中log4j 的使用
- 代码中配置log4j 参数
- java中log4j配置
- spring中使用log4j的配置
- Spring 中log4j的配置和使用
- java web项目中 Log4j 的配置
- 【日志】log4j的使用配置与参数解析
- log4j的基本配置参数
- log4j的基本配置参数
- log4j的基本配置参数
- log4j的基本配置参数
- Struts2中的OGNL详解
- OCR 自动识别
- PAT A1123. Is It a Complete AVL Tree (30)
- java反射——获取及调用方法
- win7 Redis 单机版配置
- java中Log4J使用配置参数的总结
- react中fetch方法小结
- window.open弹出悬浮框,并传递json参数
- 二分查找及简单应用
- python3 文件复制粘贴简单小例子
- 用GC日志看spark程序是不是在driver,Executor内存效率不高
- 自定义 UDF
- 星星打分
- http://www.runoob.com/java/java-tutorial.html