设为首页 收藏本站
查看: 475|回复: 0

[经验分享] Apache通用日志包使用简介

[复制链接]

尚未签到

发表于 2017-1-4 07:55:31 | 显示全部楼层 |阅读模式
日志记录为我们的项目维护提供了极具价值的参考消息,灾难性的恢复或系统改良都离不开这些信息,日志机制是日常项目开发中必不可少的一道作业工序。
 
一、Apache通用日志包简介

       Apache的通用日志包commons-logging是jakarta common(jakarta commons项目是作为JDK的补充拓展及优化的一系列方案)的日志解决方案,它提供了一组通用的第三方日志组件的接口,用户可以根据需要自由选择,同时它还把日志管理机制与我们的应用程序进行了隔离,避免应用程序的api与日志耦合在一起。
      
Apache通用日志包commons-logging.jar下载地址:
http://archive.apache.org/dist/commons/logging/commons-logging-current.zip
 
       Apache的通用日志包由于其灵活性与非侵略性的优点,已被各种framework推荐采纳使用,像struts、hibernate、spring,在tomcat安装目录的bin目录下也包含了commons-logging.jar,如今的MyEclipse6.0创建一个web project会自动将commons-logging.jar引入web/lib下,所以你几乎无需去下载和引入这个包便可使用,它已经被广泛的使用和采纳。
 
Commons日志包支持以下第三方的日志组件:
·log4j
·JDK14Logging
·LogKit
·SimpleLog
·NoOpLog
二、Apache通用日志管理机制
 
Apache通用日志等级:

Commons日志包将日志消息分为6个级别:
 
 http://welkinwwl.iteye.com/upload/attachment/pic/10128/a5bf91bc-398b-4c28-b0e0-6a20ddf21a04-thumb.gif
 
       这6个级别由上至下,由高至低。当我们在配置文件中指明日志消息的一个输出级别时(关于Commons日志包的配置方法将在后面说明),只有比这个级别高级的信息才会输出。例如:我们将日志输出级别设置为INFO,那么位于DEBUG以下级别的信息将不会输出。


Apache通用日志API:

commons-logging包下包含org.apache.commons.logging包和org.apache.commons.logging,impl包
http://welkinwwl.iteye.com/upload/attachment/pic/10129/af8aa741-a221-4112-8994-480da793d10e-thumb.gif
 
org.apache.commons.logging包:
       Log类:Log是常用的接口,声明了日志对象的使用方法;
       LogConfigurationException类:继承于RuntimeException,定义了日志的异常信息;
       LogFactory类:Log的工厂, 静态工厂方法getLog(Class clazz)和getLog(String name)返回一个Log实例,getLog(Class clazz) 和getLog(String name)具体定义如下:
             java 代码

  • publicstatic Log getLog(Class clazz) throws LogConfigurationException {   
  •          return (getFactory().getInstance(clazz));   
  •     }   
  •         publicstatic Log getLog(String name) throws LogConfigurationException {   
  •         return (getFactory().getInstance(name));   
  •     }  


 
              我们可以看出来getLog方法返回的Log实例是通过调用getFactory()返回一个 LogFactory实例再调用getInstance()方法得到的,getInstance()是一个抽象方法,getFactory方法中(由于篇幅有限,不再将getFactory源码贴出,有兴趣可以自       己看下源码)会加载commons-logging.properties属性文件(    FACTORY_PROPERTIES字段表示,关于属性配置文件稍后说明) org.apache.commons.logging.Log接口按照具体指明的类去实现,然后调   用由已 实现的getInstance方法来得到Log实例。
       LogSource类:这个类作为向上兼容,已由LogFactory取代。
org.apache.commons.logging.impl包:
       这个包包含了一些已实现了Log接口的类,不再赘述。
 
三、Apache通用日志的配置
       Commons日志配置非常简单,您只需在工程src目录下建立一个commons-logging.properties属性文件,指明org.apache.commons.logging.Log接口将由哪个第三方的日志组件来实现即可。
例如:commons-logging.properties中写入如下配置

  • org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JLogger   

     
即使用log4j来管理日志,这个Log4JLogger类只实现了一些简单的日志输出,如果要使用将日志信息输出到指定文件或其他功能需要引入log4j的类库,我会在日后写一篇关于log4j的具体使用方法与相关配置说明。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-323470-1-1.html 上篇帖子: Apache Log4j学习笔记---------详解配置文件 下篇帖子: apache+tomcat 集群学习 点滴(二)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表