`

介绍Log4j日志的使用

阅读更多

在开发应用的过程中,日志可以用于调试程序、跟踪程序的运行轨迹。在程序运行过程中,可以记录程序的运行状态,并用于审计。
日志有多种实现,Log4j是一种比较流行的实现。本文介绍Log4j日志的使用。
Log4j日志的使用包括如下过程:
l 获取日志的实现;
l 编写配置文件;
l 初始化;
l 使用。
下面分别进行介绍。
1、获取日志实现
日志实现通常位于压缩包中,压缩包的名字log4j-1.2.15.jar,存放的位置:WEB-INF/lib下面。最新版本可以从官方网站下载。
2、配置
要使用Log4j需要先进行配置,日志的配置需要使用配置文件,可以采用属性文件也可以采用XML文件,本文介绍的实例采用属性文件。属性文件的位置:WEB-INF下面,名字为:log4j.properties。
日志文件的主要内容:
1)设置跟记录器
设置根记录器的基本格式如下:
log4j.rootLogger=debug,R
等号后面包括两个信息:日志级别和日志目的。
日志级别包括:OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL
日志目的可以是任意的名字,可以有多个。
2)设置日志的类型
日志的类型包括:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
rg.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
设置日志的类型可以使用下面的代码:
log4j.appender.R=org.apache.log4j.RollingFileAppender
3)设置日志文件的相关属性
如果日志的类型是文件,需要指出文件的位置,通过如下方式指出:
log4j.appender.R.File=${catalina.home}/logs/my.log
日志文件的大小通过如下方式制定:
log4j.appender.R.MaxFileSize=10MB
日志文件重复数
log4j.appender.R.MaxBackupIndex=10
4)日志文件的输出方式
常用日志的输出方式如下:
org.apache.log4j.HTMLLayout
org.apache.log4j.PatternLayout
org.apache.log4j.SimpleLayout
org.apache.log4j.TTCCLayout
下面的代码用于设置文件输出方式:
log4j.appender.R.layout=org.apache.log4j.PatternLayout
5)日志文件的输出格式
如果使用PatternLayout,可以使用下面的格式符号。
%r 自程序开始后消耗的毫秒数
%t 表示日志记录请求生成的线程
%p 表示日志语句的优先级别
%r 与日志请求相关的类别名称
%c 日志信息所在的类
%m%n 表示日志信息的内容
例如:
log4j.appender.R.layout.ConversionPattern=%p %t %c -%m%n
下面是一个完整的配置文件的内容(#表示注释):
# debug表示日志的级别,R表示其中一个日志,名字可以随便取
log4j.rootLogger=debug, R

#日志的类型
log4j.appender.R=org.apache.log4j.RollingFileAppender

#日志的文件
log4j.appender.R.File=${catalina.home}/logs/my.log

#日志文件的大小
log4j.appender.R.MaxFileSize=10MB

#日志文件的
log4j.appender.R.MaxBackupIndex=10

#输出方式
log4j.appender.R.layout=org.apache.log4j.PatternLayout

#具体输出方式
log4j.appender.R.layout.ConversionPattern=%p %t %c -%m%n
3、初始化
可以使用多种方式进行初始化,过程基本相同。下面是采用Servlet进行初始化的例子,参考代码如下:
Servlet源文件:
package bookstore.servlet;

import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;

import org.apache.log4j.PropertyConfigurator;

public class Log4JServlet extends HttpServlet{

public void init() throws ServletException{
String path = getServletContext().getRealPath("/");
String filename = path+"/WEB-INF/log4j.properties";
PropertyConfigurator.configure(filename);
}
}
为了让Web应用启动的时候加载该Servlet,需要在web.xml中配置元素。参考代码如下:
web.xml中的声明:


xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4"]


log4j
bookstore.servlet.Log4JServlet
1

 

log4j
/log4j


4、调用
日志配置完并初始化之后,就可以使用了。使用过程主要就是获取日志器,然后调用相应的方法即可。
获取日志器的方法如下:
Logger Logger.getLogger(String str)
参数相当于指出日志的类别,返回值是Logger对象。
Logger对象用于输出日志信息的方法如下:
fatal(String info)
error(String info)
warn(String info)
info(String info)
debug(String info)
注意:在使用的时候需要导入org.apache.log4j.Logger。
下面是一个使用Log4j的例子:

 

运行结果如下:(格式为%p %t %c -%m%n):
DEBUG http-8080-1 testLogger - debug message
ERROR http-8080-1 testLogger - error message
WARN http-8080-1 testLogger - warn message
INFO http-8080-1 testLogger - info message
FATAL http-8080-1 testLogger - fatal message

5、扩展知识
正常情况下日志的使用不是在JSP文件中,而是在业务层、或者控制层,并且使用日志的文件会有很多,所以通常在基类中创建Logger对象,然后在各个子类中直接使用各个输出信息的方法即可。

分享到:
评论

相关推荐

    Log4j日志配置说明,Log4j日志配置说明

    Log4j日志配置说明,Log4j日志配置说明Log4j日志配置说明,Log4j日志配置说明

    tomcat6.0 配log4j日志的必须文件及配置过程

    tomcat6.0 配log4j日志的必须文件及配置过程 tomcat6-------lib | |--------tomcat-juli-adapters.jar | |--------log4j.jar | |--------log4j.properites | |----bin |--------tomcat-juli.jar 最后把log4...

    log4j日志管理

    log4j日志管理log4j日志管理log4j日志管理log4j日志管理log4j日志管理

    log4j使用与java中log4j记录日志如何写入数据库

    详细介绍了log4j的使用方法,介绍了java中日志记录如何写入数据库,对于初学者来说很不错的一个文档

    使用log4j2实现日志数据脱敏

    使用log4j2实现日志数据脱敏

    logstash 采集log4j日志配置文件

    logstash采集log4j日志发送到es配置文件,可以把日志根据日志级别区分开,一个级别一条日志是es中的一条数据

    Log4j日志包

    log4j.rootLogger=debug,CONSOLE,testfile,A1,MAIL ################### # Console Appender ################### log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.Target=...

    tomcat下的log4j日志配置

    tomcat下的log4j日志配置,给tomcat配置log4j有好几种方法,我知道的有: 一、tomcat级别的统一日志管理 二、每个webapp分别配置log4j

    Log4j日志管理系统简单使用说明

     禁用与使用日志请求只是Log4j其中的一个小小的地方,Log4j日志系统允许把日志输出到不同的地方,如控制台(Console)、文件(Files)、根据天数或者文件大小产生新的文件、以流的形式发送到其它地方等等。...

    log4j按功能保存日志

    log4j按功能保存日志

    log4j日志驱动包

    Log4j比较全面的配置 log4j.rootLogger=DEBUG,CONSOLE,A1,im log4j.addivity.org.apache=true # 应用于控制台 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.Threshold=DEBUG log4j....

    kettle使用log4j管理输出日志

    参照了几个网上大神配置,部分教程的描述有误,最终调试完成,可以实现kettle日志输出,测试版本...需要替换的文件为,Kettle的程序目录下data-integration-6.0\plugins\kettle5-log4j-plugin中有一个log4j.xml文件。

    log4j.CustomLogAppender 限制log4j文件保存天数

    每天生成一个log4j日志文件,如果只需要将最近一段时间内的日志文件保留,以前或更早的文件不用保留。例如只保留最近一周的日志,日志文件保留3天等等这些。。。通过这个jar包就可以实现。 log4j.properties文件在...

    log4j日志框架

    log4j日志框架 log4j日志框架 log4j日志框架log4j日志框架

    log4j日志包日志包

    log4j驱动包,里面包含log4j.properties日志文件xml

    SSM整合中的Log4j日志的配置详情

    主要介绍了SSM整合中的Log4j的配置详情,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    log4j中配置日志文件相对路径方法分析

    log4j中配置日志文件相对路径方法分析 方法一、 解决的办法自然是用相对路径代替绝对路径,其实log4j的FileAppender本身就有这样的机制,如:log4j.appender.logfile.File=${WORKDIR}/logs/app.log 其中“${...

    log4J日志.zip

    log4j日志jar包及配置文件

    log4j日志配置以及配置文件详解

    log4j配置文件以及配置文件说明 包里有一个log4j配置文件 和一个配置详解

    log4j自定义日志文件名及日志输出格式

    根据项目需要,要求日志文件名及输出的日志内容头为特殊的格式,因此重写了log4j的一些方法,如要求的格式和项目不同,可根据示例参考进行再次的修改

Global site tag (gtag.js) - Google Analytics