log4j使用
来源:互联网 发布:网络大电影 铁扇公主 编辑:程序博客网 时间:2024/06/14 00:28
1.新建一个JAva工程,导入包log4j-1.2.17.jar,整个工程最终目录如下
2、src同级创建并设置log4j.properties
需要注意的是,配置文件中的注释只可以写在每一行的开头,不能写到结尾。
<pre name="code" class="java">log4j.logger.selfPractice.RuleTest = debug, Dlog4j.logger.selfPractice.RuleTest1 = stdout,E,E2
其中,selfPractice为src下的一个package,RuleTest和RuleTest1分别为该package下的两个class。
Logger logger1 = Logger.getLogger("log1");Logger logger2 = Logger.getLogger("log2");然后再配置文件中设置如下;
log4j.logger.log1 = debug,Dlog4j.logger.log2 = stdout,E即此处的log4j.logger后面加的是该Logger的名字,在RuleTest中,是因为定义Logger时为Logger logger = Logger.getLogger(this.getClass().getName());其中this.getClass().getName(0返回的就是selfParctice.RuleTest,所以该logger的名称就叫selfPractice.RuleTest
二、Log4j基本使用方法
Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式。日志信息的优先级从高到低有ERROR、WARN、 INFO、DEBUG,分别用来指定这条日志信息的重要程度;日志信息的输出目的地指定了日志将打印到控制台还是文件中;而输出格式则控制了日志信息的显 示内容。
2.1、定义配置文件
其实您也可以完全不使用配置文件,而是在代码中配置Log4j环境。但是,使用配置文件将使您的应用程序更加灵活。Log4j支持两种配置文件格式,一种是XML格式的文件,一种是Java特性文件(键=值)。下面我们介绍使用Java特性文件做为配置文件的方法:
1.配置根Logger,其语法为:
2.配置日志信息输出目的地Appender,其语法为:
其中,Log4j提供的appender有以下几种:
3.配置日志信息的格式(布局),其语法为:
其中,Log4j提供的layout有以e几种:
Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: %m 输出代码中指定的消息
2.2、在代码中使用Log4j
1.得到记录器
使用Log4j,第一步就是获取日志记录器,这个记录器将负责控制日志信息。其语法为:
public static Logger getLogger( String name)
通过指定的名字获得记录器,如果必要的话,则为这个名字创建一个新的记录器。Name一般取本类的名字,比如:
static Logger logger = Logger.getLogger ( ServerWithLog4j.class.getName () )
2.读取配置文件
当获得了日志记录器之后,第二步将配置Log4j环境,其语法为:
3.插入记录信息(格式化日志信息)
当上两个必要步骤执行完毕,您就可以轻松地使用不同优先级别的日志记录语句插入到您想记录日志的任何地方,其语法如下:
2.3、日志级别
每个Logger都被了一个日志级别(log 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)将不会被打印出来。
log4j.additivity.myTest1 = false
它用来设置是否同时输出到log4j.rootLogger所配置的日志中,设为false就不会输出到其它地方啦!注意这里的"myTest1"是你在程序中给logger起的那个自定义的名字!
配置详解参考http://it.oyksoft.com/log4j/
- 【Log4j】Log4j使用总结
- Log4j使用
- Log4j使用
- 使用log4j
- log4j使用
- LOG4J使用
- 使用 log4j
- log4j 使用
- log4j使用
- Log4J使用
- Log4j使用
- 使用log4j
- Log4j 使用
- log4j 使用
- log4j使用
- log4j使用
- log4j使用
- log4j使用
- Hadoop集群服务器以及相关硬件选择的一些认识
- 《剑指offer》——和为S的连续正数序列
- 偏序关系中盖住关系的求取及格论中有补格的判定
- Android
- java泛型程序设计——约束与局限性
- log4j使用
- ios系列UI篇——UISwitch
- python核心编程-封包
- Java图形界面编程(一)
- cocos2d (ZORDER、setTag、单点触屏)
- UITextField用法
- 自己写的一个简单的android记事本app
- 迷宫建模
- ArcGIS API for javascript开发笔记(七)——使用ArcGIS API for javascript调用GP服务