Java中log4j的使用
前言
距离上一篇文章又过去好长时间了,这段时间一直忙于工作,已经从net彻底转向Java了。工作也慢慢的步入正轨了,自己独自完成了一个小项目,不过工作中遇到了一些问题,还是得到了同学和同事的帮助。本来想从头一点点的学习,可是时间不允许,只能边工作边学习,这样学以致用,工作中遇到了问题,然后再去查资料学习,这样学起来比较快一些。如果是刚毕业的时候,可能有时间有精力允许去从零开始学习,可是现在情况不允许这样,只能选择最快的方式学习,但是Java和net都是面向对象开发,思想都是一样的,语法上也是大同小异,因为曾经在业界流传,c#就是微软学习Java进行开发的一套语言。在Java开发中不免会使用日志的记录,最常用的就是log4j,一个很好的记录日志的方式,不久可以打印在console上,也可以输出到文件中,还可以存入数据库,操作起来很简单方便。我刚开始处理这一块的时候,不懂怎么记录系统异常,就想到了使用spring中的切面,然后在读取log4j.properties文件存入数据库,折腾了好几天,后来自己又问一下同事,自己想的太多了,完全错了。log4j可以把日志直接存入数据库的,就是简单的几行代码,没有必要那么麻烦的,自己绕了一大圈又回来了,刚开始接触,第一次情有可原,下不为例了。因此自己就私下查资料学习了一下,这次彻底记住了,最后整理了一下,跟大家分享一下了。
具体用法:下载log4j.jar包,添加到项目中,然后创建log4j.properties文件,在文件中进行配置。
Log4j的详细配置说明:
一、log4j.properties 的使用详解
1.输出级别的种类
ERROR、WARN、INFO、DEBUG
ERROR 为严重错误 主要是程序的错误
WARN 为一般警告,比如session丢失
INFO 为一般要显示的信息,比如登录登出
DEBUG 为程序的调试信息
2.配置日志信息输出目的地
log4j.appender.appenderName = fully.qualified.name.of.appender.class
(1)org.apache.log4j.ConsoleAppender(控制台)
(2)org.apache.log4j.FileAppender(文件)
(3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
(4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
(5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
3.配置日志信息的格式
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
(1)org.apache.log4j.HTMLLayout(以HTML表格形式布局),
(2)org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
(3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
(4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
4.控制台选项
Threshold=DEBUG:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
Target=System.err:默认情况下是:System.out,指定输出控制台
FileAppender 选项
Threshold=DEBUF:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt:指定消息输出到mylog.txt文件。
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
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:指定可以产生的滚动文件的最大数。
log4j.appender.A1.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n
5.日志信息格式中几个符号所代表的含义:
-X号: X信息输出时左对齐;
%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,
%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%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采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:
# %m 输出代码中指定的消息
# %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
# %r 输出自应用启动到输出该log信息耗费的毫秒数
# %c 输出所属的类目,通常就是所在类的全名
# %t 输出产生该日志事件的线程名
# %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
# %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式
# 如:%d{yyyy年MM月dd日 HH:mm:ss,SSS},输出类似:2012年01月05日 22:10:28,921
# %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数
# 如:Testlog.main(TestLog.java:10)
# %F 输出日志消息产生时所在的文件名称
# %L 输出代码中的行号
# %x 输出和当前线程相关联的NDC(嵌套诊断环境),像java servlets多客户多线程的应用中
# %% 输出一个"%"字符
#
# 可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:
# %5c: 输出category名称,最小宽度是5,category<5,默认的情况下右对齐
# %-5c:输出category名称,最小宽度是5,category<5,"-"号指定左对齐,会有空格
# %.5c:输出category名称,最大宽度是5,category>5,就会将左边多出的字符截掉,<5不会有空格
# %20.30c:category名称<20补空格,并且右对齐,>30字符,就从左边交远销出的字符截掉
二、log4j.properties的配置
1、配置步骤
1) 在应用程序中使用log4j
2) 把log4j-*.*jar放入CLASSPATH变量中
3) 新建一个配置文件log4j.properties,放于bin文件下
2、新建一个配置文件log4j.properties,如:
log4j.rootLogger=WARN, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
# Print the date in ISO 8601 format
log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
# Print only messages of level WARN or above in the package com.foo.
log4j.logger.com.foo=WARN
3、编译并运行TestLog4j会在目录下生成一个example.log的文件,屏幕也会输出信息,这证明已经你已经成功了第一步。
(1)配置根Logger,其语法为:
log4j.rootLogger = [level],appenderName,appenderName2,...
level是日志记录的优先级,分为OFF,TRACE,DEBUG,INFO,WARN,ERROR,FATAL,ALL
Log4j建议只使用四个级别,优先级从低到高分别是DEBUG,INFO,WARN,ERROR
通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。
比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来
appenderName就是指定日志信息输出到哪个地方。可同时指定多个输出目的。
(2)配置日志信息输出目的地Appender,其语法为:
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.optionN = valueN
Log4j提供的appender有以下几种:
1)org.apache.log4j.ConsoleAppender(输出到控制台)
说明:
ConsoleAppender选项属性
-Threshold = DEBUG:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-Target = System.err:默认值System.out,输出到控制台(err为红色,out为黑色)
2)org.apache.log4j.FileAppender(输出到文件)
说明:
FileAppender选项属性
-Threshold = INFO:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-File = C:\log4j.log:指定消息输出到C:\log4j.log文件
-Append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
-Encoding = UTF-8:可以指定文件编码格式
3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
说明:
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:可以指定文件编码格式
4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
说明:
RollingFileAppender选项属性
-Threshold = ERROR:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-File = C:/log4j.log:指定消息输出到C:/log4j.log文件
-Append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
-MaxFileSize = 100KB:后缀可以是KB,MB,GB.在日志文件到达该大小时,将会自动滚动.
-MaxBackupIndex = 2:指定可以产生的滚动文件的最大数
-Encoding = UTF-8:可以指定文件编码格式
5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
(3)配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.optionN = valueN
Log4j提供的layout有以下几种:
1)org.apache.log4j.HTMLLayout(以HTML表格形式布局)
说明:
HTMLLayout选项属性
-LocationInfo = TRUE:默认值false,输出Java文件名称和行号
-Title=Struts Log Message:默认值 Log4J Log Messages
2)org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
说明:
PatternLayout选项属性
-ConversionPattern = %m%n:格式化指定的消息(参数意思下面有)
3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
5)org.apache.log4j.xml.XMLLayout(以XML形式布局)
说明:
XMLLayout选项属性
-LocationInfo = TRUE:默认值false,输出java文件名称和行号
(4)指定特定包的输出特定的级别
log4j.logger.org.springframework=DEBUG,OFF,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB,ALL
log4j.rootLogger=ALL,systemOut,logFile,logDailyFile,logRollingFile,logMail,logDB
#输出到控制台
log4j.appender.systemOut = org.apache.log4j.ConsoleAppender
log4j.appender.systemOut.layout = org.apache.log4j.PatternLayout
log4j.appender.systemOut.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n
log4j.appender.systemOut.Threshold = DEBUG
log4j.appender.systemOut.ImmediateFlush = TRUE
log4j.appender.systemOut.Target = System.out
#输出到文件
log4j.appender.logFile = org.apache.log4j.FileAppender
log4j.appender.logFile.layout = org.apache.log4j.PatternLayout
log4j.appender.logFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n
log4j.appender.logFile.Threshold = DEBUG
log4j.appender.logFile.ImmediateFlush = TRUE
log4j.appender.logFile.Append = TRUE
log4j.appender.logFile.File = ../Struts2/WebRoot/log/File/log4j_Struts.log
log4j.appender.logFile.Encoding = UTF-8
#按DatePattern输出到文件
log4j.appender.logDailyFile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.logDailyFile.layout = org.apache.log4j.PatternLayout
log4j.appender.logDailyFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n
log4j.appender.logDailyFile.Threshold = DEBUG
log4j.appender.logDailyFile.ImmediateFlush = TRUE
log4j.appender.logDailyFile.Append = TRUE
log4j.appender.logDailyFile.File = ../Struts2/WebRoot/log/DailyFile/log4j_Struts
log4j.appender.logDailyFile.DatePattern = '.'yyyy-MM-dd-HH-mm'.log'
log4j.appender.logDailyFile.Encoding = UTF-8
#设定文件大小输出到文件
log4j.appender.logRollingFile = org.apache.log4j.RollingFileAppender
log4j.appender.logRollingFile.layout = org.apache.log4j.PatternLayout
log4j.appender.logRollingFile.layout.ConversionPattern = [%-5p][%-22d{yyyy/MM/dd HH:mm:ssS}][%l]%n%m%n
log4j.appender.logRollingFile.Threshold = DEBUG
log4j.appender.logRollingFile.ImmediateFlush = TRUE
log4j.appender.logRollingFile.Append = TRUE
log4j.appender.logRollingFile.File= ../Struts2/WebRoot/log/RollingFile/log4j_Struts.log
log4j.appender.logRollingFile.MaxFileSize = 1MB
log4j.appender.logRollingFile.MaxBackupIndex = 10
log4j.appender.logRollingFile.Encoding = UTF-8
#用Email发送日志
log4j.appender.logMail = org.apache.log4j.NET.SMTPAppender
log4j.appender.logMail.layout = org.apache.log4j.HTMLLayout
log4j.appender.logMail.layout.LocationInfo = TRUE
log4j.appender.logMail.layout.Title = Struts2 Mail LogFile
log4j.appender.logMail.Threshold = DEBUG
log4j.appender.logMail.SMTPDebug = FALSE
log4j.appender.logMail.SMTPHost = SMTP.163.com
log4j.appender.logMail.From = xly3000@163.com
log4j.appender.logMail.To = xly3000@gmail.com
#log4j.appender.logMail.Cc = xly3000@gmail.com
#log4j.appender.logMail.Bcc = xly3000@gmail.com
log4j.appender.logMail.SMTPUsername = xly3000
log4j.appender.logMail.SMTPPassword = 1234567
log4j.appender.logMail.Subject = Log4j Log Messages
#log4j.appender.logMail.BufferSize = 1024
#log4j.appender.logMail.SMTPAuth = TRUE
#将日志登录到MySQL数据库
log4j.appender.logDB = org.apache.log4j.jdbc.JDBCAppender
log4j.appender.logDB.layout = org.apache.log4j.PatternLayout
log4j.appender.logDB.Driver = com.mysql.jdbc.Driver
log4j.appender.logDB.URL = jdbc:mysql://127.0.0.1:3306/xly
log4j.appender.logDB.User = root
log4j.appender.logDB.Password = 123456
log4j.appender.logDB.Sql = INSERT INTOT_log4j(project_name,create_date,level,category,file_name,thread_name,line,all_category,message)values('Struts2','%d{yyyy-MM-ddHH:mm:ss}','%p','%c','%F','%t','%L','%l','%m')
# 将日志按照包分类输出的配置文件
#根针对所有的日志包
log4j.rootLogger = debug , appendConsole
#下面两个配置是指定包的特殊处理,针对两个指定的日志级别,如果不指定的话则使用父日志记录器(rootLogger)的,指定了就覆盖掉了父日志记录器的
#设置dao包的日志配置
log4j.logger.com.xun.log4j.dao = debug, appendDao
#设置service包的日志配置
log4j.logger.com.xun.log4j.service = info, appendService
#控制台的配置
log4j.appender.appendConsole = org.apache.log4j.ConsoleAppender
Threshold:设置此appender的日志级别,这里会覆盖全局的(rootLogger中)定义的日志级别
log4j.appender.appendConsole.Threshold = error
#设置日志输出编码方式为UTF-8,如果不指定,会以当前运行操作系统的编码方式记录
log4j.appender.appendConsole.encoding = UTF-8
log4j.appender.appendConsole.layout = org.apache.log4j.SimpleLayout
#appendDao配置
log4j.appender.appendDao = org.apache.log4j.FileAppender
log4j.appender.appendDao.layout = org.apache.log4j.PatternLayout
log4j.appender.appendDao.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n
log4j.appender.appendDao.Append = false
log4j.appender.appendDao.File = e:/test/log4j/dao.txt
#appendService
log4j.appender.appendService = org.apache.log4j.FileAppender
log4j.appender.appendService.layout = org.apache.log4j.PatternLayout
log4j.appender.appendService.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n
log4j.appender.appendService.Append = false
log4j.appender.appendService.File = e:/test/log4j/service.txt
一些XML文件配置
(1)log4j.xml
log4j.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!--
* 1. 一个appender子元素定义一个日志输出目的地
* 2. 一个logger子元素定义一个日志写出器
-->
<!-- catalina.out -->
<appender name="consoleAppend" class="org.apache.log4j.ConsoleAppender" >
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p][%t][%c{1}]-[%M] %m%n" />
</layout>
</appender> <!-- error log -->
<appender name="errorAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/error/error.html" />
<param name="Append" value="true" />
<param name="DatePattern" value="yyyy-MM-dd-HH-mm'.html'"/>
<param name="MaxBackupIndex" value="10" />
<param name="MaxFileSize" value="4000000" />
<param name="encoding" value="utf-8"/>
<layout class="org.apache.log4j.HTMLLayout">
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="ERROR" />
<param name="LevelMax" value="ERROR" />
</filter>
</appender>
<!-- biz -->
<appender name="bizAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/biz/biz.log" />
<param name="Append" value="true" />
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<param name="MaxBackupIndex" value="10" />
<param name="MaxFileSize" value="4096" />
<param name="encoding" value="utf-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="[date:%d{yyyy-MM-dd HH:mm:ss}] %m%n" />
</layout>
<filter class="com.raycloud.bizlogger.LoggerFilter">
<param name="LevelMin" value="40050" />
<param name="LevelMax" value="40050" />
</filter>
</appender>
<!-- 消费者消费的消息记录 -->
<appender name="taskExcutorAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/excutor/excutor.log" />
<!-- 每小时1个文件 -->
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<!-- 最大文件的size,单位:Kb,Mb... -->
<param name="MaxFileSize" value="4096" />
<!-- 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 -->
<param name="Append" value="true"/>
<!-- 默认 MaxBackupIndex 为 1 -->
<param name="MaxBackupIndex" value="10" />
<param name="Encoding" value="utf-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="WARN" />
</filter>
</appender>
<!-- ProcessHandler的日志 -->
<appender name="processHandlerAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/process/process.log" />
<!-- 每小时1个文件 -->
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<!-- 最大文件的size,单位:Kb,Mb... -->
<param name="MaxFileSize" value="4096" />
<!-- 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 -->
<param name="Append" value="true"/>
<!-- 默认 MaxBackupIndex 为 1 -->
<param name="MaxBackupIndex" value="10" />
<param name="Encoding" value="utf-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="WARN" />
</filter>
</appender>
<!-- command node js的日志 -->
<appender name="nodejsAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/command/nodejs.log" />
<!-- 每小时1个文件 -->
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<!-- 最大文件的size,单位:Kb,Mb... -->
<param name="MaxFileSize" value="4096" />
<!-- 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 -->
<param name="Append" value="true"/>
<!-- 默认 MaxBackupIndex 为 1 -->
<param name="MaxBackupIndex" value="10" />
<param name="Encoding" value="utf-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="WARN" />
</filter>
</appender>
<!-- command ffmpeg的日志 -->
<appender name="ffmpegAppend" class="org.apache.log4j.DailyRollingFileAppender">
<param name="File" value="${webapp.root}/logs/command/ffmpeg.log" />
<!-- 每小时1个文件 -->
<param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
<!-- 最大文件的size,单位:Kb,Mb... -->
<param name="MaxFileSize" value="4096" />
<!-- 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 -->
<param name="Append" value="true"/>
<!-- 默认 MaxBackupIndex 为 1 -->
<param name="MaxBackupIndex" value="10" />
<param name="Encoding" value="utf-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="WARN" />
</filter>
</appender> <!--
logger的作用:
1.[name属性]:指定你定义Logger对象时候的name
2. additivity : children-logger是否使用 rootLogger的配置,
additivity在log4j默认为true。这解释了为什么有些时候,一个日志信息在屏幕上会有多次输出。
3.还可以指定level(输出级别)、appender-ref(指定哪个append)
-->
<!-- loggers -->
<logger name="com.raycloud.picture.task.consumer.PictureVideoTaskExcutor" additivity="true">
<!-- 如果1个包想对应多个 Appender 就这样,对于每个Appender自定义的日志级别可以在Appender上加上filter -->
<appender-ref ref="taskExcutorAppend" />
</logger>
<logger name="com.raycloud.picture.task.handle.impl.DefaultVideoProcessorHandleImpl" additivity="true">
<appender-ref ref="processHandlerAppend" />
</logger>
<logger name="com.raycloud.picture.service.command.NodeJsCommandInvoke" additivity="true">
<appender-ref ref="nodejsAppend" />
</logger>
<logger name="com.raycloud.picture.service.command.FfmpegCommandInvoke" additivity="true">
<appender-ref ref="ffmpegAppend" />
</logger> <!--
root的作用(相当于全局的意思):
1.[priority ]:指定默认的全局输出级别
2.[appender-ref ]:指定一些默认的append(没有指出特殊包或者类,即那些没有指定<logger>元素的append)的输出;
-->
<root>
<priority value="INFO" />
<!-- 将 logger 中 additivity=true 的日志或者没有指定<logger>的append输出到控制台 -->
<appender-ref ref="consoleAppend" />
<!-- 将全局的 error 日志输出到error文件中 -->
<appender-ref ref="errorAppend" />
<appender-ref ref="bizAppend" />
</root>
</log4j:configuration>
(2)log4j.xml在web.xml中的配置
log4j.xml在web.xml中的配置
<!-- log4j -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>classpath:log4j-server.xml</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>3000</param-value>
</context-param>
<!-- 先开启Log4J,再去启动spring等一些你需要的东西,有助于报错时日志的输出 -->
<listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener> log4j操作:
方式一:自动快速的使用Log4J缺省的环境
BasicConfigurator.configure();
方式二:读取properties文件(自定义位置),但是注意这里文件的加载路径 PropertyConfigurator.configure("E:/workspace-idea/study-demo/log4j-test/src/main/resources/log4j/log4j.properties"); PropertyConfigurator.configure(HowUseLog4JDemo.class.getClassLoader().getResource("log4j/log4j.properties").getFile());
方式三:读取XML文件
DOMConfigurator.configure("xxx");
总结:时间比较紧张,写的比较匆忙,可能表述不清楚,或者写的不对,有错的地方希望大家帮忙指出。好东西就要分享,一起学习一起进步!(*^__^*) 嘻嘻……
Java中log4j的使用的更多相关文章
- Java 中Log4j的使用详情
Log4j 真的很简单,简单到令人发指的地步.不是要记录日志吗?那就给你一个Log ,然后你用Log 来写东西就行了,先来一个完整类示例: package test; import org.apach ...
- java中log4j用法详细讲解和一些小总结
0.Log4j的用法详解 首先,在项目中的classes 中新建立一个log4j.properties文件即可: 在实际编程时,要使Log4j真正在系统中运行事先还要对配置文件进行定义.定义步骤就是对 ...
- 【转】详细讲解Java中log4j的使用方法
转载地址:http://www.233.com/Java/zhuangye/20070731/142625631.html 1.Log4j是什么? Log4j可以帮助调试(有时候debug是发挥不了作 ...
- java中log4j的使用体验
log4j相信大部分java开发者都已经很熟悉了,在此记录下自己的使用过程. 一.文件准备: 1.log4j.jar(我这里使用的版本是log4j-1.2.17.jar,在附件中提供下载) 2.log ...
- java中Log4J的使用笔记
使用Log4J,程序员可以控制日志信息输送的目的地,包括控制台,文件,GUI组件和NT事件记录器,也可以控制每一条日志的输出格式,或通过定义每一条日志信息的级别,更加细致地控制日志的生成过程. Log ...
- java中log4j学习笔记
Log4j是apache的一个开源项目,用来操作程序日志信息的框架.因便于管理,在工程中用来代替System.out打印语句.通过配置Log4j中的log4j.properties,可以指定日志信息的 ...
- slf4j+log4j在Java中实现日志记录
小Alan今天来跟大家聊聊开发中既简单又常用但必不可少的一样东西,那是什么呢?那就是日志记录,日志输出,日志保存. 后面就统一用日志记录四个字来形容啦. 日志记录是项目的开发中必不可少的一个环节,特别 ...
- JAVA中使用log4j及slf4j进行日志输出的方法详解
JAVA中输出日志比较常用的是log4j,这里讲下log4j的配置和使用方法,以及slf4j的使用方法. 一.下载log4j的架包,并导入项目中,如下: 二.创建log4j.properties配置 ...
- JAVA中的Log4j
Log4j的简介: 使用异常处理机制==>异常 使用debug调试(必须掌握) System.out.Print(); 001.控制台行数有限制 002.影响性能 ...
随机推荐
- iOS 快速集成启动页广告
前言 由于项目中要用到启动页广告,所以做了简单的研究,同时借鉴网易新闻和蘑菇街的交互写了一个简单的demo,现在写出来供大家参考,可能由于个人局限会有一些bug和不完善的地方,也希望大家能够友善提醒和 ...
- 每天一个linux命令(33)--du命令
Linux du命令也是查看使用空间的,但是与 df 命令不同的是 Linux du 命令是对文件和目录磁盘使用的空间的查看,还是和df 命令有一些区别的. 1.命令格式: du [选项] [文 ...
- AR入门系列-04-vuforia识别多个图片及同屏展示
首先,我们需要在官网中识别数据库添加多张图片,并将数据库下载下来覆盖原来的数据库 在 Hierarchy视图中需要多个ImageTarget 将新建的ImageTarget(1) 选择数据库中的识别图 ...
- 查找第K小数
题目描述 查找一个数组的第K小的数,注意同样大小算一样大. 如 2 1 3 4 5 2 第三小数为3. 输入描述: 输入有多组数据.每组输入n,然后输入n个整数(1<=n<=1000), ...
- 使用IDEA的gradle整合spring+ mybatis 采用javaconfig配置
1.新建一个工程 2.工程目录 3.添加gradle.propertes文件 activeMQVersion=5.7.0 aspectJVersion=1.7.2 commonsLangVersion ...
- aiohttp之添加静态资源路径
所谓静态资源,是指图片.js.css等文件.官方的说明在这里. 以一个小项目来说明,下面是项目的目录结构: . ├── static │ ├── css │ │ ├── base.css │ │ ├─ ...
- jeesite学习(一) common部分(1)
我们按照先细节后整体的方式来进行学习,即先了解各个包中包含的内容,再从整体上看各个包之间的关系. 0 common中的包 先看jeesite的common组件,common中共包含14个包(如下图), ...
- 机器学习基石 1 The Learning Problem
机器学习基石 1 The Learning Problem Introduction 什么是机器学习 机器学习是计算机通过数据和计算获得一定技巧的过程. 为什么需要机器学习 1 人无法获取数据或者数据 ...
- Cordova原理一
我们知道cordova中js要和native通信都是通过 cordova plugin来实现的.如果我们自己创建一个cordova plugin,它其实就是几个独立的文件按照一定的目录结构放在一起,然 ...
- Calender设置固定时间遇到的问题
在使用Calender获取实例,设置成UTC时区时,发现比我们常规的月份多了一个月: 示例代码如下: Calendar calendar = Calendar.getInstance(TimeZone ...