一、log4J的使用步骤
1 配置文件
log4j需要使用配置文件进行配置,共两种方式,一种为properties文件,一种为xml文件。
Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式。日志信息的优先级从高到低有ERROR、WARN、INFO、DEBUG,分别用来指定这条日志信息的重要程度;日志信息的输出目的地指定了日志将打印到控制台还是文件中;而输出格式则控制了日志信息的显示内容。
配置文件应放在classpath下面 或者在类中指明配置文件所在位置
PropertyConfigurator.configure("src/LogJDBC.properties");
#控制台输出
#优先级debug>info>error
#log4j推荐使用的级别是 debug info warn error
log4j.rootLogger=debug,appender1
#控制台输出
log4j.appender.appender1=org.apache.log4j.ConsoleAppender
log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
# %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
# %r 输出自应用启动到输出该log信息耗费的毫秒数
#%c 输出所属的类目,通常就是所在类的全名
#%t 输出产生该日志事件的线程名
#%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
#%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
#%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
log4j.appender.appender1.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
2 控制台输出
将日志信息输出到控制台
#控制台输出
#优先级debug>info>error
#log4j推荐使用的级别是 debug info warn error
log4j.rootLogger=debug,appender1
#控制台输出
log4j.appender.appender1=org.apache.log4j.ConsoleAppender
log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
# %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
# %r 输出自应用启动到输出该log信息耗费的毫秒数
#%c 输出所属的类目,通常就是所在类的全名
#%t 输出产生该日志事件的线程名
#%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
#%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
#%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
log4j.appender.appender1.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
3 输出到文件
# 输出到文件
#定义根输出
log4j.rootLogger=debug,appenderF
#定义文件输出
log4j.appender.appenderF=org.apache.log4j.FileAppender
#输出文件位置
log4j.appender.appenderF.File=E:\\test.log
#追加文件内容
log4j.appender.appenderF.Append=true
#定义输出格式
log4j.appender.appenderF.layout=org.apache.log4j.PatternLayout
log4j.appender.appenderF.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
4 输出到按大小滚动文件
定义每个日志文件的大小 超过大小将自动生成新的日志文件
#按文件大小滚动输出
log4j.rootLogger=debug,f
log4j.appender.f=org.apache.log4j.RollingFileAppender
log4j.appender.f.File=D:/log/rol.log
log4j.appender.f.Append=true
#文件达到10K就自动更名
log4j.appender.f.MaxFileSize=10KB
#最多备份100个文件
log4j.appender.f.MaxBackupIndex=100
log4j.appender.f.layout=org.apache.log4j.PatternLayout
log4j.appender.f.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
5 输出到按日期滚动文件
按日期滚动文件输出将日志输出到指定的文件,到日期发生变化时,会将文件按指定的日期格式自动改名。
#按照日期滚动输出
log4j.rootLogger=debug,f
log4j.appender.f=org.apache.log4j.DailyRollingFileAppender
log4j.appender.f.File=D:/log/logDaily.log
log4j.appender.f.DatePattern=.yyyy-MM-dd
log4j.appender.f.layout=org.apache.log4j.PatternLayout
log4j.appender.f.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
6 输出到JDBC数据库
将日志输出到数据库
#输出到数据库
log4j.rootLogger=debug,db
#定义输出到数据库
log4j.appender.db=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.db.URL=jdbc:mysql://172.20.201.191:3306/test
log4j.db.driver=com.mysql.jdbc.Driver
log4j.db.user=admin
log4j.db.password=123456
log4j.db.sql=insert into log4j (logTime,logLevel,logMsg,logClass) values('%d','%p','%m','%c')
log4j.appender.db.layout=org.apache.log4j.PatternLayout
log4j.appender.db.layout.ConversionPattern=%-d{yyyy-MM-dd hh:mm:ss,SSS}>>>>[%C]-[%p] >>>>%m%n
二、日志输出
在java代码中,使用log4j输出日志信息很简单,只需指定特定类型的信息并进行输出显示即可。在spring中,可以利用IOC直接获取日志对象 进行操作。
public static Logger logger=Logger.getLogger(TestMain.class.toString());
static
{
Handler console=new ConsoleHandler();
console.setLevel(Level.OFF);
logger.addHandler(console);
}
public static void main(String[] args)
{
logger.setLevel(Level.ALL);
logger.fine("fine");
logger.finer("finer");
logger.config("config");
logger.info("info");
logger.severe("server");
}
版权声明:本文为博主原创文章,未经博主允许不得转载。