Log4j1.2配置详解
Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控制日志的输出到控制台,或者文件等等。
同时,在各大框架中也主要是使用log4j来进行日志的输出。
下面是log4j1.x版本的详细配置:
在1.x版本的log4j中,只需要一个依赖包:log4j-1.x.x.jar
要使用log4j还需要一个配置文件(log4j.properties),来指定log输出的具体方式。
先来看一个简单的实现。
在这个例子中,没有使用配置文件,仅仅用的是默认的配置。
package com.fuwh.demo; import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.Level;
import org.apache.log4j.Logger; public class Log4jDemo01 { public static void main(String[] args) {
//初始化logger
Logger log=Logger.getLogger(Log4jDemo01.class);
//加载默认的配置信息
BasicConfigurator.configure();
log.log(Level.ERROR, "这是err log");
log.debug("这是debug log");
log.info("这是info log"); }
}
输出结果:
1 [main] ERROR com.fuwh.demo.Log4jDemo01 - 这是err log
2 [main] DEBUG com.fuwh.demo.Log4jDemo01 - 这是debug log
3 [main] INFO com.fuwh.demo.Log4jDemo01 - 这是info log
如果改用配置文件的话就是这样的
#log4j.properties #set root logger level to DEBUG and its only appender to A1
log4j.rootLogger=DEBUG,A1 #A1 is set to be a ConsoleAppender
log4j.appender.A1=org.apache.log4j.ConsoleAppender #A1 uses PatternLayout
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n
package com.fuwh.demo; import org.apache.log4j.Level;
import org.apache.log4j.Logger; public class Log4jDemo01 { public static void main(String[] args) {
//初始化logger
Logger log=Logger.getLogger(Log4jDemo01.class);
log.info("log等级:"+log.getLevel()); log.log(Level.ERROR, "这是err log");
log.debug("这是debug log");
log.info("这是info log");
}
}
输出信息:
0 [main] INFO com.fuwh.demo.Log4jDemo01 - log等级:null
2 [main] ERROR com.fuwh.demo.Log4jDemo01 - 这是err log
2 [main] DEBUG com.fuwh.demo.Log4jDemo01 - 这是debug log
2 [main] INFO com.fuwh.demo.Log4jDemo01 - 这是info log
log4j总共有三个组件:loggers,appenders,layouts。
log4j的配置文件可以是XML文件或者是java的属性文件。
在log4j中的logger是分等级层次的,最顶层的是rootLogger,其他的logger都会继承他。
意思就是说:名字为:com.foo的logger是继承自 名为com的logger,名为com的logger又是继承自rootLogger。
而每一个logger都可以指定输出信息的等级。
等级是在org.apache.log4j.Level类中定义的,共有下面这些:
TRACE:表示细粒度的一些信息
DEBUG:表示调试信息
INFO:表示一般的信息
WARN:表示警告信息
ERROR:表示一般的错误信息
FATAL:表示致命的错误
而且这些等级是有顺序的,顺序为:
DEBUG < INFO < WARN < ERROR < FATAL
当你指定输出等级之后,只有大于或等于这个等级的消息才会被输出。
意思就是说,当你指定输出等级为INFO的时候,INFO和WARN,ERROR,FATAL等等消息会被输出,
但是DEBUG信息不会被输出。
log4j.properties文件的详细配置
配置根Logger
log4j.rootLogger=等级, appenderName , appenderName 。。。
指定rootLogger的输出等级,并且输出到appenderName这个目的地,这个名字可以自己随便取
主要用来在下面配置stdout或者R的其他详细信息的时候用的一个名字。
配置输出目的地Appender
log4j.appender.appenderName=appender class name
用来指定输出的类型,还可以指定以下的输出方式:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),可通过log4j.appender.R.MaxFileSize=100KB设置文件大小,还可通过org.apache.log4j.MaxBackupIndex=1设置为保存一个备份文件。
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
例如:log4j.appender.stdout=org.apache.log4j.ConsoleAppender
定义一个名为stdout的输出目的地,ConsoleAppender为控制台。
配置日志信息的输出格式
Layout用来格式化Appender的输出
log4j.appender.appenderName.layout=layout class name
log4j.appender.appenderName.layout.option1 = value1
在log4j中提供的layout有以下几种:
格式化日志
下面是一个典型的log4j配置:
#log4j.properties #set root logger level to DEBUG and its only appender to A1
log4j.rootLogger=INFO,Console,logFile ##Console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n ##logFile
log4j.appender.logFile=org.apache.log4j.RollingFileAppender
log4j.appender.logFile.File=D:\\coding\\log4j.txt
log4j.appender.logFile.MaxFileSize=1KB
log4j.appender.logFile.MaxBackupIndex=3
log4j.appender.logFile.layout=org.apache.log4j.PatternLayout
log4j.appender.logFile.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n #define log level for special class to overrid rootlogger
#log4j.logger.java.sql.ResultSet=INFO
#log4j.logger.org.apache=INFO
#log4j.logger.java.sql.Connection=DEBUG
#log4j.logger.java.sql.Statement=DEBUG
#log4j.logger.java.sql.PreparedStatement=DEBUG
小技巧:
有时候,可能你希望某个包或者某个类中的log信息不被输出,或者输出更加详细的,或者更加简单的信息,则可以单独配置来覆盖rootLooger的配置,例如:
#log4j.logger.org.apache=INFO
Log4j1.2配置详解的更多相关文章
- Hibernate4搭建Log4J日志管理(附Log4j.properties配置详解)
1.首先加入slf4j的jar包,即slf4j-api-1.6.1.jar 在hibernate官网下载hibernate-release-4.2.2.Final.zip并解压,在hibernate- ...
- JAVAEE——spring01:介绍、搭建、概念、配置详解、属性注入和应用到项目
一.spring介绍 1.三层架构中spring位置 2.spring一站式框架 正是因为spring框架性质是属于容器性质的. 容器中装什么对象就有什么功能.所以可以一站式. 不仅不排斥其他框架,还 ...
- Tomcat记录-tomcat常用配置详解和优化方法(转载)
常用配置详解 1 目录结构 /bin:脚本文件目录. /common/lib:存放所有web项目都可以访问的公共jar包(使用Common类加载器加载). /conf:存放配置文件,最重要的是serv ...
- log4j.properties配置详解与实例
log4j.properties配置详解与实例 第一步:加入log4j-1.x.x.jar到lib下. 第二步:在工程的src下下建立log4j.properties.内容如下: #OFF,syste ...
- tomcat常用配置详解和优化方法
tomcat常用配置详解和优化方法 参考: http://blog.csdn.net/zj52hm/article/details/51980194 http://blog.csdn.net/wuli ...
- spring-搭建-概念-配置详解-属性注入
1 spring介绍 三层架构中spring位置 spring一站式框架 正是因为spring框架性质是属于容器性质的. 容器中装什么对象就有什么功能.所以可以一站式. 不仅不排斥其他框架,还能帮其 ...
- Log4j配置详解(转)
一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...
- logback 常用配置详解<appender>
logback 常用配置详解 <appender> <appender>: <appender>是<configuration>的子节点,是负责写日志的 ...
- [转]阿里巴巴数据库连接池 druid配置详解
一.背景 java程序很大一部分要操作数据库,为了提高性能操作数据库的时候,又不得不使用数据库连接池.数据库连接池有很多选择,c3p.dhcp.proxool等,druid作为一名后起之秀,凭借其出色 ...
随机推荐
- WCF配置问题(配置WCF跨域)
其它的先放一边.今天先来分享一下前段时间给公司做网站WCF服务接口的心得. 配置文件的配置问题 这里既然讨论WCF配置文件的问题,那么怎么创建的就不一一讲解了.好多博主都有提过的.所以直接分享自己开发 ...
- python IDLE中反斜杠显示为人民币符号¥的解决办法
改换英文字体即可
- Beta项目复审
Beta项目复审 复审人:张宇光 所属团队:MyGod 团队成员:程环宇.王田路.张芷祎.张宇光.王婷婷 团队排名: SW_HW4-team团队 hyw-team团队 Java-Team团队 C++团 ...
- bzoj千题计划177:bzoj1858: [Scoi2010]序列操作
http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...
- JAVA_SE基础——54.异常
异常的体系: ----------| Throwable 所以异常或者错误类的超类 --------------|Error 错误 错误一般是用于jvm或者是硬件引发的问题,所以我们一般不会通 ...
- 遍历JSON
第一种: each,不做详细说明,太常用了 第二种:我用来遍历单个组,实现前端界面绑定 for(var item in person){ alert("person中"+item+ ...
- 1.phpStrom连接远程代码
1.选择一个新的文件 2.选择自己需要的传输方式 3.添加项目名+路径 4.填写连接基本信息 5.配置成功,下载完毕后,设计本地与远程代码同步修改 自此本地修改代码,同时修改远程服务器代码就设置完毕~ ...
- OAuth2.0学习(1-11)新浪开放平台微博认证-使用OAuth2.0调用微博的开放API
使用OAuth2.0调用API 使用OAuth2.0调用API接口有两种方式: 1. 直接使用参数,传递参数名为 access_token URL 1 https://api.weibo.com/2/ ...
- 使用java 打印日历
package hangshu; /* * 打印从1900年到2.year年的日历 */ import java.util.Scanner; public class Calender { publi ...
- 使用nodeJS的 crypto模块来为你的密码hash加盐
这篇文章将向你解释如何使用Node.js的Crypto模块对你的密码进行加盐hash.在这里,我们将不会对不懂的密码存储方式进行详细的比较.我们将要做的是知道在Node.js中使用加盐hash在进行密 ...