Log4j与common-logging 介绍

一.Log4j
1.简介
Log4j是Apache的一个开放源代码项目
使用Log4j,我们可以很方便的来记录日志.
http://www.apache.org/dist/logging/log4j/1.2.14/下载最新的稳定版本

2.用法
把log4j-1.2.14.jar丢到lib目录下,使用log4j前需要定义配置文件,也可以不使用,而是在代码中配置log4j环境.但是使用配置文件使应用程序更加灵活。

log4j配置文件有三个主要的组件:Logger,Appender和Layout,分别为日志类型,日志输出目的地,日志输出格式.

跟proxool类似,log4j支持两种类型的配置文件,xml和properties
log4j.properties配置文件如下:(需要把log4j的配置文件放在classpath下)

log4j.rootLogger = [level], appenderName, appenderName, ... (level是错误级别,appenderName是输出目的地,可以定义多个)

level优先级分别为FATAL、ERROR、WARN、INFO、DEBUG 5个级别.通过定义的级别,你可以控制程序中的日志输出.比如在这里定义了ERROR级别,程序中只有FARAL、ERROR 级别的LOG会被输出.

log4j.appender.appenderName = 输出目的地(这里的appenderName是在前面定义的,可任意起名)
Log4j提供的输出目的地有以下几种:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件到达指定大小时产生一个新文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任何地方)

log4j.appender.mylog.File = dir
log4j.appender.mylog.MaxFileSize=fileSize
log4j.appender.mylog.MaxBackupIndex=num设置保存备份文件数量

log4j.appender.appenderName.layout = 布局类型 (设置布局类型)
1Log4j提供的layout有以下4种:
2org.apache.log4j.HTMLLayout(以HTML表格形式布局)
3org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
4org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
5org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
如果使用PatternLayout布局就要指定的打印信息的具体格式ConversionPattern,
打印参数如下:
1%m 输出代码中指定的消息
2%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
3%r 输出自应用启动到输出该log信息耗费的毫秒数
4%c 输出所属的类目,通常就是所在类的全名
5%t 输出产生该日志事件的线程名
6%n 输出一个回车换行符,Windows为"rn",Unix为"n"
7%d 输出日志时间,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出:200751719:30:00,000
8%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数
9[QC]是log信息的开头,可以为任意字符,一般为项目简称
最简单通用的配置文件(从控制台打印):
1log4j.rootLogger=info,mylog
2log4j.appender.mylog=org.apache.log4j.ConsoleAppender
3log4j.appender.mylog.layout=org.apache.log4j.PatternLayout
4log4j.appender.mylog.layout.ConversionPattern=[-] %p %d{yyyy-MM-dd HH:mm:ss} %m %n
5或者
6log4j.rootLogger=info,mylog
7log4j.appender.mylog=org.apache.log4j.ConsoleAppender
8log4j.appender.mylog.layout=org.apache.log4j.SimpleLayout
在代码中log4j的使用:
首先需要导入日志类
1import org.arache.log4j.Logger;
2static Logger logger = Logger.getLogger(your-className.class);
3#需要插入日志的地方只需
4logger.debug(your-message);
5logger.info(your-message);
6logger.warn(your-message);
7logger.error(your-message);
8logger.fatal(your-message);
写程序的时候,为了调试,会加入大量的logger信息,当然程序调试完毕不需要这些输出信息时,只需把输出的级别调高,如调到error级别,这样error以下级别的logger就不会出输出.非常简单,方便.

二.commons-logging介绍
log4j与commons-logging两个包,都是记日志的,为什么要两个一起用呢?
commons-logging是为"所有的Java日志实现"提供一个统一的接口,它自身的日志功能平常弱,而log4j功能非常强大全面,所以拿两者配合使用.
commons-logging工作原理:
1. 首先在classpath下寻找自己的配置文件commons-logging.properties,如果找到,则使用其中定义的Log实现类
2. 如果找不到commons-logging.properties文件,则在查找是否已定义系统环境变量org.apache.commons.logging.Log,找到则使用其定义的Log实现类
3. 查看classpath中是否有Log4j的包,如果发现,则自动使用Log4j作为日志实现类
4. 使用JDK自身的日志实现类(JDK1.4以后才有日志实现类)
5. 使用commons-logging自己提供的一个简单的日志实现类SimpleLog
(以上顺序不保证完全准确,请参考官方文档)
commons-logging总是能找到一个日志实现类,并且尽可能找到一个"最合适"的日志实现类.
1、可以不需要配置文件
2、自动判断有没有Log4j包,有则自动使用之
3、最悲观的情况下也总能保证提供一个日志实现(SimpleLog)
另外一直觉得log4j的使用方式有点问题
static Logger logger = Logger.getLogger(message);
每个需要写日志的java类都得创建一个static logger实例,如果java类很多的话,那创建这些static对象的开销将非常大,所以最后自己写一个log类,有一个静态方法可以得到logger实例
01import org.apache.commons.logging.Log;
02import org.apache.commons.logging.LogFactory;
03
04public class Logs {
05privatestatic Log log;
06static{
07log=LogFactory.getLog(Logs.class);
08}
09publicstatic Log getLogger(){
10returnlog;
11}
12}
三.关于Log4j比较全面的配置
LOG4J的配置之简单使它遍及于越来越多的应用中了:Log4J配置文件实现了输出到控制台、文件、 回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了

log4j.rootLogger=DEBUG,CONSOLE,A1,im
log4j.addivity.org.apache=true

# 应用于控制台
1log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
2log4j.appender.Threshold=DEBUG
3log4j.appender.CONSOLE.Target=System.out
4log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
5log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
6#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%

#应用于文件
1log4j.appender.FILE=org.apache.log4j.FileAppender
2log4j.appender.FILE.File=file.log
3log4j.appender.FILE.Append=false
4log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
5log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
6# Use thislayout for LogFactor 5 analysis
# 应用于文件回滚
1log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
2log4j.appender.ROLLING_FILE.Threshold=ERROR
3log4j.appender.ROLLING_FILE.File=rolling.log
4log4j.appender.ROLLING_FILE.Append=true
5log4j.appender.ROLLING_FILE.MaxFileSize=10KB
6log4j.appender.ROLLING_FILE.MaxBackupIndex=1
7log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
8log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
#应用于socket
01log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender
02log4j.appender.SOCKET.RemoteHost=localhost
03log4j.appender.SOCKET.Port=5001
04log4j.appender.SOCKET.LocationInfo=true
05# Set up forLog Facter 5
06log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
07log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n
08
09
10# Log Factor 5Appender
11log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
12log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000
# 发送日志给邮件
1log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
2log4j.appender.MAIL.Threshold=FATAL
3log4j.appender.MAIL.BufferSize=10
4log4j.appender.MAIL.From=web@www.wuset.com
5log4j.appender.MAIL.SMTPHost=www.wusetu.com
6log4j.appender.MAIL.Subject=Log4J Message
7log4j.appender.MAIL.To=web@www.wusetu.com
8log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
9log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n
# 用于数据库
01log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
02log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
03log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
04log4j.appender.DATABASE.user=root
05log4j.appender.DATABASE.password=
06log4j.appender.db.sql=INSERT INTO SS_LOG4J_LOG (PRIORITY,LOGDATE,CLASS,METHOD,MSG) VALUES('%p','%d{yyyy-MM-dd HH:mm:ss}','%C','%M','%m')
07log4j.appender.db.layout=org.apache.log4j.PatternLayout log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
08log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n <PREclass=java name="code">
09
10log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
11log4j.appender.A1.File=SampleMessages.log4j
12log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
13log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout </PRE>
14<BR>
15<BR><SPAN style="COLOR: green">#自定义Appender </SPAN>
16<BR><PRE class=java name="code">log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
17
18log4j.appender.im.host = mail.cybercorlin.net
19log4j.appender.im.username = username
20log4j.appender.im.password = password
21log4j.appender.im.recipient = corlin@cybercorlin.net
22
23log4j.appender.im.layout=org.apache.log4j.PatternLayout
24log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n</PRE>
25<BR>
26<BR>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值