log4j是Java开发平台中的日志管理工具,是Apache基金会的一个开源项目。它的作用能够简单的理解为在开发过程中替代system.out的功能。

1、在project中集成log4j:

(1)在官网http://logging.apache.org/log4j/2.x/download.html中下载版本号log4j-1.2.9.jar包(仅仅需加入该log4j jar包就可以)并加入到build path中

(2)改动配置文件log4j.properties,能够百度一下。这样的资源非常多,我的配置文件例如以下:

log4j.rootLogger =DEBUG,console,file,D,E #设置日志级别和日志输出目的地,级别仅仅能有一个。目的地能够由多个

log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n #warn:before write the file log.log, clear it
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.file=./log.log
log4j.appender.file.Append = false #注意:每次写文件前,清空,做试验用,默认值为true
log4j.appender.file.DatePattern='.'yyyy-MM-dd
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
#log4j.appender.file.layout=org.apache.log4j.TTCCLayout
#org.apache.log4j.TTCCLayout do not have the property such as ConversionPattern #test output different log information to seperate file
#set the DEBUG level information output to the file debug.log
#warn:before write the file debug.log, clear it
log4j.appender.D=org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.file=./debug.log
log4j.appender.D.Append = false #注意:每次写文件前,清空,做试验用,默认值为true
log4j.appender.D.Threshold = DEBUG #仅仅有比DEBUG级别高的日志才会输出到debug.log文件里,相当于五种类型的日志都会保存到debug.log中
log4j.appender.D.DatePattern='.'yyyy-MM-dd
log4j.appender.D.layout=org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n #set the ERROR level information output to the file debug.log
#warn:before write the file error.log, clear it
log4j.appender.E=org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.file=./error.log
log4j.appender.E.Append = false #注意:每次写文件前,清空,做试验用,默认值为true
log4j.appender.E.Threshold = ERROR #仅仅有比ERROR级别高的日志才会输出到error.log文件里,相当于error.log文件仅仅保存FATAL和ERROR类型的日志
log4j.appender.E.DatePattern='.'yyyy-MM-dd
log4j.appender.E.layout=org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n

(3)优先级说明:log4j中有5种优先级,须要注意的是优先级数据越小其优先级越高(0最高。7最低),当设置某种优先级后。比其高的级别日志都会输出。比如,假设在log4j.rootLogger
=DEBUG,console,file,D,E设置的为DEBUG。则全部级别的日志都会输出,由于DEBUG级别最低。这点在实现不同级别的日志信息写到不同的文件时很重要。

FATAL 0

ERROR 3

WARN 4

INFO 6

DEBUG 7

2、log4j的初始化

在网上搜了下。发现有三种方式进行初始化:

(1)自己主动载入配置文件。这个对配置文件的存放位置有要求,我这里的是Java seproject。配置文件放在src文件夹下;若是放在project根文件夹下,载入失败,会出现例如以下错误:

log4j:WARN No appenders could be found for logger (Log4jTest).
log4j:WARN Please initialize the log4j system properly.

(2)手动载入配置文件,在main方法里利用语句(注意依据配置文件的路径自己调整):

PropertyConfigurator.configure("./log4j.properties");

(3)不用配置文件。直接在代码中设置。

关于log4j的初始化过程,有篇博客以xml格式的配置文件为例,从源代码级别上做了解释http://tiangu.iteye.com/blog/1153777

3、log4j实现不同类型的日志输出到不同的文件

这里必须设置log4j.appender.xxx.Threshold属性。仅仅有比该级别高的日志才会输出到该日志文件里。

详见上面的配置文件凝视。

Javaproject集成log4J 1.x的更多相关文章

  1. Javaproject集成log4j 2.x

    log4j2和log4j在配置文件和引入jar包上出现了不同.这里做个备忘,这里使用的版本号为apache-log4j-2.3-bin.zip. 1.apache-log4j-2.3-bin.zip下 ...

  2. SSH集成log4j日志环境[转]

    第一步:在web.xml初始化log4j <context-param> <param-name>log4jConfigLocation</param-name> ...

  3. SSH集成log4j日志环境

    第一步:在web.xml初始化log4j <context-param> <param-name>contextConfigLocation</param-name> ...

  4. Spring MVC集成Log4j

    以下示例显示如何使用Spring Web MVC框架集成LOG4J.首先使用Eclipse IDE,并按照以下步骤使用Spring Web Framework开发基于动态表单的Web应用程序: 创建一 ...

  5. springboot集成log4j

    需求: 1.springboot集成log4j 2.mybatis 打印 sql 实现: pom.xml <dependency> <groupId>org.springfra ...

  6. SpringBoot 集成Log4j、集成AOP

    集成Log4j (1)在pom.xml中添加依赖 <!--去掉springboot默认的日志--> <dependency> <groupId>org.spring ...

  7. SpringBoot集成log4j,解决log4j.properties不生效问题

    Spring Boot集成log4j其实比较简单,maven的话,在xml中增加log4j依赖就行 <dependency> <groupId>org.springframew ...

  8. (OAF)jdeveloper集成log4j并将日志输出到指定文件并写入数据库

    参考: How to configure Log4j in JDev 11g Ever wanted to use log4j in your adf project ? Well though Or ...

  9. spring 集成 log4j 配置

    在web.xml中增加如下代码: <context-param> <param-name>log4jConfigLocation</param-name> < ...

随机推荐

  1. ACM_梦中的函数

    梦中的函数 Time Limit: 2000/1000ms (Java/Others) Problem Description: 寒假那段时间,每天刷题的小G连做梦都是代码,于是有了这道题. 给定一个 ...

  2. sqlite学习笔记之sqlite3_open函数的使用

    作者:朱金灿 来源:http://blog.csdn.net/clever101 打开sqlite数据库需要用到sqlite3_open函数,但是sqlite3_open函数的第一个参数是数据库文件的 ...

  3. JS高级——arguments

    arguments 1.函数内部的一个对象,在函数调用的时候,默认的会将所有传入的实参依次存入该对象 2.是一个伪数组 3.arguments.length 可以用来表示传入实参的个数 4.argum ...

  4. 3星|《腾讯产业森林:AI时代的创业密码》:后半部分是较详细的创业指南,前面泛泛介绍腾讯、AI

    腾讯产业森林:AI时代的创业密码 前半部分泛泛介绍腾讯对创业者的支持,腾讯支持的创业项目的案例.AI的一些基本介绍,后半部分是比较详细的写给创业者的各阶段行动与选择的指南. 总体评价3星,有一些参考价 ...

  5. iOS crash log 解析 symbol address = stack address - slide 运行时获取slide的api 利用dwarfdump从dsym文件中得到symbol

    概述: 为什么 crash log 内 Exception Backtrace 部分的地址(stack address)不能从 dsym 文件中查出对应的代码? 因为 ASLR(Address spa ...

  6. jquery ajax中各个事件执行顺序如下

    $(function(){ setTimeout(function(){ $.ajax({ url:'/php/selectStudent.php', }); },0); $(document).aj ...

  7. Idea 创建maven web项目(手工创建)

    参考链接:https://www.cnblogs.com/justuntil/p/7511787.html 话不多说,直接上图: 1.创建maven项目 创建项目完成,项目结构如下: 2.项目部署配置 ...

  8. jq购物车结算功能

    css *{font-style: normal} .gw{margin: 8px;} .gw::after{display: block;clear: both;content: '';margin ...

  9. python包与模块

    Python基础-包与模块 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含__init__.py文件). 模块搜索路径,Py ...

  10. sysbench测试阿里云ECS云磁盘的IOPS,吞吐量

    测试阿里云ECS 对象:在aliyun上买了一个ECS附加的云盘,使用sysbench测试云盘的IOPS和吞吐量 sysbench prepare 准备文件,10个文件,1个1G [root@iZwz ...