• Log4j与commonlogging


    本文转载地址:http://nopainnogain.iteye.com/blog/780444

    转载声明:转载本文只是用于个人学习,个人尽力告知原作者并请求转载。由于某方面原因未能告知请见谅,原作者如若不允许转载,请留言。本人会在第一时间内删掉本转载文章

    ------------------------------------------------------------------------------------- 以下为正文  -------------------------------------------------------------------------------------------------------

    总网上搜了些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 = 布局类型 (设置布局类型) 

    Xml代码 复制代码 收藏代码
    1. Log4j提供的layout有以下4种:   
    2. org.apache.log4j.HTMLLayout(以HTML表格形式布局)   
    3. org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)   
    4. org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)   
    5. org.apache.log4j.PatternLayout(可以灵活地指定布局模式)  

    如果使用PatternLayout布局就要指定的打印信息的具体格式ConversionPattern, 

    打印参数如下:

    Xml代码 复制代码 收藏代码
    1. %m 输出代码中指定的消息<SPAN style="COLOR: #ff0000">message</SPAN>(即你用log的info或errer,debug等方法的输出信息)   
    2. %p 输出优先级(<SPAN style="COLOR: #ff0000">primary</SPAN>),即DEBUG,INFO,WARN,ERROR,FATAL   
    3. %r 输出自应用启动到输出该log信息耗费的毫秒数   
    4. %c 输出所属的类目,通常就是所在类(<SPAN style="COLOR: #ff0000">class</SPAN>)的全名   
    5. %t 输出产生该日志事件的线程(<SPAN style="COLOR: #ff0000">thread</SPAN>)名   
    6. %n 输出一个回车换行符,Windows为"rn",Unix为"n"   
    7. %d 输出日志时间(<SPAN style="COLOR: #ff0000">date,最后的SSS应该是计算前面后剩下的毫秒数</SPAN>),比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出:2007年5月17日 19:30:00,000   
    8. %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数<SPAN style="COLOR: #ff0000">line</SPAN>  
    9. [QC]是log信息的开头,可以为任意字符,一般为项目简称  
    Xml代码 复制代码 收藏代码
    1. <SPAN style="LINE-HEIGHT: 18px; FONT-FAMILY: Arial, sans-serif, Helvetica, Tahoma; WHITE-SPACE: normal">可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:    
    2. 1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。    
    3. 2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,”-”号指定左对齐。    
    4. 3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。    
    5. 4)%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边交远销出的字符截掉。 </SPAN>   

    最简单通用的配置文件(从控制台打印): 

    Xml代码 复制代码 收藏代码
    1. log4j.rootLogger=info,mylog   
    2. log4j.appender.mylog=org.apache.log4j.ConsoleAppender   
    3. log4j.appender.mylog.layout=org.apache.log4j.PatternLayout   
    4. log4j.appender.mylog.layout.ConversionPattern=[-] %p %d{yyyy-MM-dd HH:mm:ss} %m %n   
    5. 或者   
    6. log4j.rootLogger=info,mylog   
    7. log4j.appender.mylog=org.apache.log4j.ConsoleAppender   
    8. log4j.appender.mylog.layout=org.apache.log4j.SimpleLayout  

    首先需要导入日志类 

    Java代码 复制代码 收藏代码
    1. import org.arache.log4j.Logger;   
    2. static Logger logger = Logger.getLogger(your-className.class);   
    3. #需要插入日志的地方只需   
    4. logger.debug(your-message);   
    5. logger.info(your-message);   
    6. logger.warn(your-message);   
    7. logger.error(your-message);   
    8. logger.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实例 

    Java代码 复制代码 收藏代码
    1. import org.apache.commons.logging.Log;   
    2. import org.apache.commons.logging.LogFactory;   
    3.   
    4. public class Logs {   
    5.     private static Log log;   
    6.     static{   
    7.         log=LogFactory.getLog(Logs.class);   
    8.     }   
    9.     public static Log getLogger(){   
    10.         return log;   
    11.     }   
    12. }   

    三.关于Log4j比较全面的配置 

    LOG4J的配置之简单使它遍及于越来越多的应用中了:Log4J配置文件实现了输出到控制台、文件、 回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能。择其一二使用就够用了 

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

    # 应用于控制台 

    Xml代码 复制代码 收藏代码
    1. log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender    
    2. log4j.appender.Threshold=DEBUG    
    3. log4j.appender.CONSOLE.Target=System.out    
    4. log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout    
    5. log4j.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%n   

    #应用于文件

    Xml代码 复制代码 收藏代码
    1. log4j.appender.FILE=org.apache.log4j.FileAppender    
    2. log4j.appender.FILE.File=file.log    
    3. log4j.appender.FILE.Append=false    
    4. log4j.appender.FILE.layout=org.apache.log4j.PatternLayout    
    5. log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n    
    6. # Use this layout for LogFactor 5 analysis   

    # 应用于文件回滚

    Java代码 复制代码 收藏代码
    1. log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender    
    2. log4j.appender.ROLLING_FILE.Threshold=ERROR    
    3. log4j.appender.ROLLING_FILE.File=rolling.log    
    4. log4j.appender.ROLLING_FILE.Append=true    
    5. log4j.appender.ROLLING_FILE.MaxFileSize=10KB    
    6. log4j.appender.ROLLING_FILE.MaxBackupIndex=1    
    7. log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout    
    8. log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n   

    #应用于socket 

    Xml代码 复制代码 收藏代码
    1. log4j.appender.SOCKET=org.apache.log4j.RollingFileAppender    
    2. log4j.appender.SOCKET.RemoteHost=localhost    
    3. log4j.appender.SOCKET.Port=5001    
    4. log4j.appender.SOCKET.LocationInfo=true    
    5. # Set up for Log Facter 5    
    6. log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout    
    7. log4j.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    
    8.   
    9.   
    10. # Log Factor 5 Appender    
    11. log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender    
    12. log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000   
     # 发送日志给邮件 
    Java代码 复制代码 收藏代码
    1. log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender    
    2. log4j.appender.MAIL.Threshold=FATAL    
    3. log4j.appender.MAIL.BufferSize=10    
    4. log4j.appender.MAIL.From=web@www.wuset.com    
    5. log4j.appender.MAIL.SMTPHost=www.wusetu.com    
    6. log4j.appender.MAIL.Subject=Log4J Message    
    7. log4j.appender.MAIL.To=web@www.wusetu.com    
    8. log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout    
    9. log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n 
       

     # 用于数据库 

    Xml代码 复制代码 收藏代码
    1. log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender    
    2. log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test    
    3. log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver    
    4. log4j.appender.DATABASE.user=root    
    5. log4jlog4j.appender.DATABASE.password=    
    6. log4j.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')   
    7. log4j.appender.db.layout=org.apache.log4j.PatternLayout log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout    
    8. log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n <pre name="code" class="java">  
    9.   
    10. log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender    
    11. log4j.appender.A1.File=SampleMessages.log4j    
    12. log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'    
    13. log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout </pre>  
    14. <br>  
    15. <br><span style="color: green">#自定义Appender </span>  
    16. <br><pre name="code" class="java">log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender    
    17.   
    18. log4j.appender.im.host = mail.cybercorlin.net    
    19. log4j.appender.im.username = username    
    20. log4j.appender.im.password = password    
    21. log4j.appender.im.recipient = corlin@cybercorlin.net    
    22.   
    23. log4j.appender.im.layout=org.apache.log4j.PatternLayout    
    24. log4j.appender.im.layout.ConversionPattern =[framework] %d - %c -%-4r [%t] %-5p %c %x - %m%n</pre>  
    25. <br>  
    26. <br>  
    27.      

    下面是自己使用的log4j的一个简单例子:

    将commons-logging-api-1.0.4.jar和log4j-1.2.15.jar包加入类路径下,并将log4j默认加载的log4j.properties配置文件放到classpath下,配置log4j.properties文件的日志显示信息格式:

    Java代码 复制代码 收藏代码
    1. log4j.rootLogger=INFO,A1,R   
    2. log4j.appender.A1=org.apache.log4j.ConsoleAppender   
    3. log4j.appender.A1.layout=org.apache.log4j.PatternLayout   
    4. log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n   
    5.   
    6. log4j.appender.R=org.apache.log4j.RollingFileAppender   
    7. log4j.appender.R.File=./logs/training.log   
    8. log4j.appender.R.MaxFileSize=500KB   
    9. log4j.appender.R.MaxBackupIndex=1  
    10. #log4j.appender.R.layout=org.apache.log4j.HTMLLayout   
    11. log4j.appender.R.layout=org.apache.log4j.PatternLayout   
    12. log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] [%c] [%p] - %m%n  

     在类里使用log4j:

    Java代码 复制代码 收藏代码
    1. import org.apache.log4j.Logger;   
    2.   
    3.   
    4. public class LogTest {   
    5.   
    6.     private Logger log = Logger.getLogger(this.getClass());   
    7.        
    8.     public void abc(){   
    9.         log.info("测试一下日志的使用!");   
    10.         log.info("成功了没有,呵呵");   
    11.     }   
    12.        
    13.     public static void main(String[] args){   
    14.         LogTest test = new LogTest();   
    15.         test.abc();   
    16.     }   
    17.        
    18. }  

    注意这里我引入的是log4j的类,而不是common的loger类,因为我引入common的logger类时,它没有使用log4j的配置文件,而是使用

    自己默认的输出格式,也就是log4j不能用,所以我才改了用log4j的类的引入,这样就可以按log4j的配置文件的格式来输出了。输入的文件默认放在工程的根目录下,当然我们也可以改为绝对路径。

  • 相关阅读:
    Visual Studio中View页面与Js页面用快捷键互相跳转
    使用NLog记录业务日志到数据库
    Js笛卡尔乘积
    多线程更新一个表里面的不同行也可能会死锁
    当请求参数与网站编码不一致时乱码解决方法
    WIN7下vs2010滑轮滚动不正确的解决方法
    VS 2017 代码报错编译正常
    C#表达式树
    .net core 学习 读取配置文件
    .net core 上传文件Demo
  • 原文地址:https://www.cnblogs.com/hlantian/p/10194594.html
Copyright © 2020-2023  润新知