log4j的使用方法

一.log4j是具有日志记录功能,主要通过一个配置文件来对程序进行监测
有两种配置方式:一种程序配置,一种文件配置.

有三个主要单元要了解,Logger,appender,layout.logger是进行记录的主要类,appender是记录的方式,layout是记录的格式
logger七种日志级别:debug,info,warn,error,fatal,all,off
最常用的应该是debug()和info();而warn()、error()、fatal()仅在相应事件发生后才使用

1.1appender主要分三类,终端输出,文件输出,流输出

ConsoleAppender
FileAppender
WriterAppender
对应的详细实现类为org.apache.log4j.FileAppender,
org.apache.log4j.JDBCAppender,连接数据库的日志文件输出
org.apache.log4j.ConsoleAppender。

1.2layout也分三类:简单格式,html格式,匹配格式

SimpleLayout
HTMLLayout
PatternLayout

输出简写:(用在PatternLayout)
%m 输出代码中指定的消息
%p 输出优先级
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,通常就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。一般使用了它就不需使用%c了

[按照下面步骤来写吧!就可以得到我们所想要的日志文件哦!]


[按照顺序就可以将日志文件读出来了!]
作用实例:
程序配置一般过程:
1.得到特定名称的logger
2.得到其中一个layout
3.根据layout得到appender
4.logger添加appender
5.logger设置级别
6.logger输出有级别的日志信息

程序:
Logger logger = Logger.getLogger(Test.class.getName())     //取得logger
SimpleLayout simpleLayut = new SimpleLayout()              //取得layout
FileAppender fa = new FileAppender(simpleLayout,"test.log") //取得ppender
logger.addAppender(fa)                                     //添加appender
logger.set((Level)Level.DEBUG)                             //设置级别
logger.debug("hihihihih")                                  //记录信息

配置文件:log4j.properties

 ### 设置###
log4j.rootLogger = debug,stdout,D,E

### 输出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

### 输出DEBUG 级别以上的日志到=E://logs/error.log ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = E://logs/log.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = DEBUG 
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 输出ERROR 级别以上的日志到=E://logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =E://logs/error.log 
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR 
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

maven工程导入log4j日志模块

1.在idea里配置log4j流程:
如果连接数据库的话,就要导入import org.apache.log4j.Logger;

2.然后将log4j.properties 文件放在project的resources文件夹下面
在pom文件里
****是使用了slf4j具体为什么适用slf4j而不使用log4j后面详细研究*****
 <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
 </dependency>

或者

<dependency>
        <groupId>log4j</groupId>
        <artifactId>log4j</artifactId>
        <version>1.2.17</version>
    </dependency>
    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>1.7.21</version>
    </dependency>

3.使用log
package com.mucfc;
import org.apache.log4j.Logger;
/**
 *@author linbingwen
 *@2015年5月18日9:14:21
 */
public class Test {
    private static Logger logger = Logger.getLogger(Test.class);  
 
    /** 
     * @param args 
     */  
    public static void main(String[] args) {  
        // System.out.println("This is println message.");  
 
        // 记录debug级别的信息  
        logger.debug("helloWorld.");  
        // 记录info级别的信息  
        logger.info("This is info message.");  
        // 记录error级别的信息  
        logger.error("This is error message.");  
    }  
 
}
4、输出结果、
[DEBUG] 2019-05-05 17:41:36,274 method:first_maven.main(first_maven.java:8)
helloWorld

总结:

其中:
log4j是基于Apache Software License发行的可靠、快速、可扩展的日志框架。
log4j具有高可配置性,可以在运行的过程中通过外部文件配置它。log4j能够根据不同的级别优先权来过滤日志,
并且提供了一种机制,能够将日志记录直接写到控制台,文件,数据库,UNIX系统日志等
log4j主要由logger(记录器),appender(输出源),layout(布局模式)三部分组成,其中logger用来捕获日志信息,layout用来对日志信息进行格式化,appender用来定义日志的输出源。
log4j的安装方式与添加普通的.jar类库文件相同
log4j.properties配置文件分为三部分,第一部分配置了日志文件的保存目录logDir,
同时说明将日志的过滤级别设置为DEBUG,输出源是FILE;
第二部分配置了输出源的详细实现类org.apache.log4j.FileAppender,日志文档名称log.txt;
第三部分则规定了日志文档的布局模式PatternLayout,及详细的格式化参数%m%n。
2,将日志写入数据库需要经历
(1)建立MySQL数据库日志记录表,
(2)配置log4j配置文件,
(3)编写Java执行程序三大步骤,下面将详细阐述三个步骤的具体内容。
日志写入MySQL时,数据源是DB,详细的实现类是JDBCAppender

driver    设置连接数据库的驱动程序,如MySQL的驱动字符串为:com.mysql.jdbc.Driver;
URL    设置数据库的连接字符串;
user    设置数据库的用户名;
password    设置数据库的密码;
sql    设置操作数据库的SQL语句;

Java程序中并没有涉及到JDBC的操作,是怎么将日志写到MySQL数据的?
”其实log4j采用了一种机制,能够将日志直接写到数据库,换言之,对数据库的操作已经由log4j框架本身承包了。
将日志写进文件时也没有涉及到文件操作,原因同上。
log4j兼容其他数据库,实际上只要是关系型数据库,log4j都能够很好支持。
import org.apache.log4j.Logger;
一般建立logger 修饰符伟 static 或者final 
private static final Logger logger =Logger.getLogger(类名);
static修饰既节约空间,效率也好.

final 是本 logger 不能再指向其他 Logger 对象
 

猜你喜欢

转载自blog.csdn.net/qq_41324009/article/details/90017580