三、log4j
log4j跟其它logger机制一样,存在着基本的logger所有基本概念,只是它的fomatter叫做patternLayout, 而handler则叫做appender. 另外log4j和java util logging在level的划分上有所不同,log4j的level分为:TRACE,DEBUG,INFO,WARN,ERROR,FATAL,ALL。
1.工程结构
2.配置文件(本文以property方式,xml方式请查看其他)
<span style="font-size:18px;">####输出级别为 debug,目的地为appender1(可以指定多个):
log4j.rootLogger=debug,appender1,appender2,appender3
####appender1 配置(控制台输出):
#输出位置:
log4j.appender.appender1=org.apache.log4j.ConsoleAppender
#输出格式:
log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout
####appender2 配置(文件输出,html格式):
#输出位置:
log4j.appender.appender2=org.apache.log4j.FileAppender
#输出位置:
log4j.appender.appender2.File=D:/appender2.html
#输出格式:
log4j.appender.appender2.layout=org.apache.log4j.HTMLLayout
####appender3 配置(文件输出,自定义格式):
#输出位置:
log4j.appender.appender3=org.apache.log4j.FileAppender
#输出位置:
log4j.appender.appender3.File=D:/appender3.txt
#输出格式:
log4j.appender.appender3.layout=org.apache.log4j.PatternLayout
#自定义样式 , %r 时间 ,%t方法名 main,%p优先级 DEBUG/INFO/ERROR ,
#%c所属类的全名(包括包名),%l 发生的位置,在某个类的某行 ,%m 输出代码中指定的讯息,%n输出一个换行符号
log4j.appender.appender3.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%C-%M] %m%n</span>
说明:
1).配置根Logger,其语法为:
log4j.rootLogger = [ level ] , appenderName, appenderName, …
其中,level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别,优 先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定 义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。 appenderName就是指B日志信息输出到哪个地方。您可以同时指定多个输出目的地。
2).配置日志信息输出目的地Appender,其语法为:
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
…
log4j.appender.appenderName.option = valueN
其中,Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
3).配置日志信息的格式(布局),其语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
…
log4j.appender.appenderName.layout.option = valueN
其中,Log4j提供的layout有以e几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: %m 输出代码中指定的消息
%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 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
3.代码:
<span style="font-size:18px;">public class Log4jTest {
//第一步:日志记录
private static Logger log = Logger.getLogger(Log4jTest.class);
public static void main(String[] args) throws Exception {
//第二步:读取配置文件(默认读取根目录下log4j.properties)
/*
BasicConfigurator.configure (): 自动快速地使用缺省Log4j环境。
PropertyConfigurator.configure ( String configFilename) :读取使用Java的特性文件编写的配置文件。
DOMConfigurator.configure ( String filename ) :读取XML形式的配置文件。
*/
//第三步:插入日志信息
log.debug("debug...信息");
log.info("info...信息");
log.error("error...信息");
}
}</span>
4.效果:
四、Commons-logging
目的是为所有流行的logging提供一个通用接口。用户在开发的时候只需要调用commons logging的接口。而运行环境中具体使用的是log4j,util logging或其它的logging, 则由commons logging配置文件或者commons logging的自动探测来决定。
在系统开发中,统一按照commons-logging的API进行开发,在部署时,选择不同的日志系统包,即可自动转换到不同的日志系统上。比如:开始选择JDK自带的日志系统,,如果中途无法忍受JDK自带的日志系统了,想换成log4j的日志系统,仅需要导入log4j.jar即可
Commons Logging包含三个jar:
commons-logging-api.jar 这里面包含了commons logging的通用接口以及两个logger的实现:SimpleLog和NoOpLog.
commons-logging.jar 这里面包含了通用接口,以及Log4j,JDK logger等的适配器。这个是最常用的包。
commons-logging-adapters.jar 只包含了第三方logger的适配器。必须和上面两个包中的一个搭配使用。
使用Commons-logging的LogFactory获取日志处理类时:
- 首先在classpath下寻找自己的配置文件commons-logging.properties,如果找到,则使用其中定义的Log实现类;
- ???如果找不到commons-logging.properties文件,则在查找是否已定义系统环境变量org.apache.commons.logging.Log,找到则使用其定义的Log实现类;
- 否则,查看classpath中是否有Log4j的包,如果发现,则自动使用Log4j作为日志实现类;
- 否则,使用JDK自身的日志实现类(JDK1.4以后才有日志实现类);
- 否则,使用commons-logging自己提供的一个简单的日志实现类SimpleLog;
使用Log4j:
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新