log4j2 logger标签log4j使⽤教程
Log4j简介
Log4j是Apache的⼀个开放源代码项⽬,通过使⽤Log4j,我们可以控制⽇志信息输送的⽬的地是控制台、⽂件、GUI组件、甚⾄是套接⼝服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每⼀条⽇志的输出格式;通过定义每⼀条⽇志信息的级别,我们能够更加细致地控制⽇志的⽣成过程。最令⼈感兴趣的就是,这些可以通过⼀个配置⽂件来灵活地进⾏配置,⽽不需要修改应⽤的代码。
以Java项⽬为例介绍log4j配置步骤
⼯程结构如下:
1.添加log4j相关jar包(maven)
<!--添加log4j相关jar包-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.16</version>
</dependency>
2.log4j.properties配置
#⽇志配置
#控制台输出
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.Threshold=DEBUG
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss}[ %p ]%m%n
#所有⽂件输出
log4j.appender.file = org.apache.log4j.FileAppender
log4j.appender.file.File = D:/logs/log.log
log4j.appender.file.Encoding=UTF-8
log4j.appender.file.name = fileLogDemo
log4j.appender.file.Threshold=DEBUG
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c {Num}] [%l] [ %t:%r ] - [ %p ]  %m%n
log4j.appender.file.append = true
3.测试类
import org.apache.log4j.Logger;
public class log4jTest {
//获取⽇志记录器Logger,名字为本类类名
private static Logger logger = Logger(log4jTest.class);
public static void main(String[] args) {
for(int i=0;i<3;i++){
// 记录debug级别的信息
logger.debug("log4j⽇志输出:This is debug message.");
// 记录info级别的信息
logger.info("log4j⽇志输出:This is info message.");
// 记录error级别的信息
<("log4j⽇志输出:This is error message.");
}
}
}
控制台输出结果
⽇志⽂件输出结果
log4j配置说明
log4j包含三个组件,分别是 Logger(记录器)、Appender(输出⽬的地)、Layout(⽇志布局)。可分别简单理解为"⽇志类别"、"⽇志要输出的地⽅"和"⽇志以何种形式输出"。
1、配置Logger记录器
level表⽰⽇志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者你定义的级别。
Log4j建议使⽤四个级别,优先级从⾼到低分别是ERROR、WARN、INFO、DEBUG。
通过在这⾥定义的级别,你可以控制到应⽤程序中相应级别的⽇志信息的开关。⽐如在这⾥定义了INFO级别,则应⽤程序中所有DEBUG级别的⽇志信息将不被打印出来。
appenderName就是指⽇志输出的⽬的。你可以灵活地定义⽇志输出,也可以同时指定多个输出⽬的地。
Log4j配置⽂件实现了输出到控制台、⽂件、回滚⽂件、发送⽇志邮件、输出到数据库⽇志表、⾃定义标签等全套功能。
2、配置Appender输出⽬的地
输出⽬的地类型:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(⽂件),
org.apache.log4j.DailyRollingFileAppender(每天产⽣⼀个⽇志⽂件),
org.apache.log4j.RollingFileAppender(⽂件⼤⼩到达指定尺⼨的时候产⽣⼀个新的⽂件),
org.apache.log4j.WriterAppender(将⽇志信息以流格式发送到任意指定的地⽅)
3、配置layout⽇志布局
org.apache.log4j.HTMLLayout(HTML表格形式)
org.apache.log4j.SimpleLayout(简单格式的⽇志,只包括⽇志信息的级别和指定的信息字符串,如:DEBUG - Hello)
org.apache.log4j.TTCCLayout(⽇志的格式包括⽇志产⽣的时间、线程、类别等等信息)
org.apache.log4j.PatternLayout(灵活地⾃定义⽇志格式)
使⽤org.apache.log4j.PatternLayout来⾃定义信息格式时,可以使⽤ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c {Num}] [%l] [
%t:%r ] - [ %p ]  %m%n 来格式化信息
%c 输出所属类的全名,可写为 %c{Num} ,Num类名输出的范围如:"com.sun.aaa.classB",%C{2}将使⽇志输出输出范围为:aaa.classB
%d 输出⽇志时间其格式为可指定格式如 %d{HH:mm:ss}等
%l 输出⽇志事件发⽣位置,包括类⽬名、发⽣线程,在代码中的⾏数
%n 换⾏符
%m 输出代码指定信息,如info(“message”),输出message
%p 输出⽇志的优先级,即 FATAL ,ERROR 等
%r 输出从启动到显⽰该条⽇志信息所耗费的时间(毫秒数)
%t 输出产⽣该⽇志事件的线程名

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。