`
sunqitang
  • 浏览: 78619 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

log4j 详细解读与common-logging结合

阅读更多

Log4J的配置文件(Configuration File)就是用来设置记录器的级别、存放器和布局的,它可接key=value格式的设置或xml格式的设置信息。通过配置,可以创建出Log4J的运行环境。

1. 配置文件
Log4J配置文件的基本格式如下:

#配置根Logger
log4j.rootLogger 
=   [ level ]   ,  appenderName1 ,  appenderName2 ,
 …

#配置日志信息输出目的地Appender
log4j.appender.appenderName 
=
 fully.qualified.name.of.appender.class 
  log4j.appender.appenderName.option1 
=
 value1 
  … 
  log4j.appender.appenderName.optionN 
=
 valueN 

#配置日志信息的格式(布局)
log4j.appender.appenderName.layout 
=
 fully.qualified.name.of.layout.class 
  log4j.appender.appenderName.layout.option1 
=
 value1 
  … 
  log4j.appender.appenderName.layout.optionN 
=  valueN 

其中 [level] 是日志输出级别,共有5级:
FATAL      0  
ERROR     
3
 
WARN      
4
 
INFO      
6
 
DEBUG     
7


Appender
为日志输出目的地,Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台),
org.apache.log4j.FileAppender(文件),
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

Layout :日志输出格式,Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局),
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

打印参数: Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,如下:
  %m    输出代码中指定的消息
  %p    输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL 
  %r    输出自应用启动到输出该log信息耗费的毫秒数 
  %c    输出所属的类目,通常就是所在类的全名 
  %t    输出产生该日志事件的线程名 
  %n    输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” 
  %d    输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss
, SSS},输出类似:2002年10月18日  22 10 28 921
 
  %l    输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:
10

2. 在代码中初始化Logger:
1)在程序中调用BasicConfigurator.configure() 方法:给根记录器增加一个ConsoleAppender,输出格式通过PatternLayout设为"%-4r [%t] %-5p %c %x - %m%n" ,还有根记录器的默认级别是Level.DEBUG .
2)配置放在文件里,通过命令行参数传递文件名字,通过PropertyConfigurator.configure(args[x]) 解析并配置;
3)配置放在文件里,通过环境变量传递文件名等信息,利用log4j默认的初始化过程解析并配置;
4)配置放在文件里,通过应用服务器配置传递文件名等信息,利用一个特殊的servlet来完成配置。

3. 为不同的 Appender 设置日志输出级别:
当调试系统时,我们往往注意的只是异常级别的日志输出,但是通常所有级别的输出都是放在一个文件里的,如果日志输出的级别是BUG!?那就慢慢去找吧。
这时我们也许会想要是能把异常信息单独输出到一个文件里该多好啊。当然可以,Log4j已经提供了这样的功能,我们只需要在配置中修改AppenderThreshold
就能实现,比如下面的例子:

[配置文件]
### set log levels ###
log4j.rootLogger
= debug ,  stdout ,  D ,
 E

### 输出到控制台 ###
log4j.appender.stdout
=
org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target
=
System.out
log4j.appender.stdout.layout
=
org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern
=  %d{ABSOLUTE} %5p %c{ 1
}:%L - %m%n

### 输出到日志文件 ###
log4j.appender.D
=
org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File
=
logs/log.log
log4j.appender.D.Append
=
true
log4j.appender.D.Threshold
=
DEBUG ## 输出DEBUG级别以上的日志
log4j.appender.D.layout
=
org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern
= %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]
 %m%n

### 保存异常信息到单独文件 ###
log4j.appender.D
=
org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File
=
logs/error.log ## 异常日志文件名
log4j.appender.D.Append
=
true
log4j.appender.D.Threshold
=
ERROR ## 只输出ERROR级别以上的日志!!!
log4j.appender.D.layout
=
org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern
= %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

[代码中使用]
public   class  TestLog4j  {
    
public   static   void  main(String[] args) 
{
        PropertyConfigurator.configure(
" D:/Code/conf/log4j.properties "
);
        Logger logger 
=  Logger.getLogger(TestLog4j. class
);
        logger.debug(
" debug "
);
        logger.error(
" error "
);
    }

}

运行一下,看看异常信息是不是保存在了一个单独的文件error.log中。

  在我们的日常开发中,经常需要通过输出一些信息进行程序的调试,如果到处都用system.out.println()则在项目发布之后要逐一删除,而 log4j提供了一种新的调试输出机制以解决输出的问题。log4j的原理是使用一个配置文件log4j.properties进行管理,在调试的时候可 以把输出级别调低,项目正式发布之后把级别调高,这样以前的一些输出就可以屏蔽了,不用到程序当中再进行逐一删除。关于log4j的介绍网上很多,随便 google一下就可以顺利的使用log4j了。在这里介绍一下log4j和common-logging的联合使用,因为在很多框架当中都是结合了 common-logging和log4j的应用。像spring之类的框架里面存在很多debug输出,用common-logging可以很容易的打 印输出,以用于了解spring的运行机制!
   使用介绍:
   1.下载jar包:
       log4j-1.2.9.jar和commons-logging.jar
   2.在web目录的classes下面添加两个文件: commons-logging.properties和log4j.properties       
      log4j.properties(例子):
          ##LOGGERS##
          #define a logger
          log4j.rootLogger=INFO,console,file
          #log4j.rootLogger=DEBUG,console,file
          ##APPENDERS##
         #define an appender named console,which is set to be a ConsoleAppender
         log4j.appender.console=org.apache.log4j.ConsoleAppender
         #define an appender named file,which is set to be a RollingFileAppender
         log4j.appender.file=org.apache.log4j.RollingFileAppender
         log4j.appender.file.File=log-wst.txt
         ##LAYOUTS##
         #assign a SimpleLayout to console appender
         log4j.appender.console.layout=org.apache.log4j.SimpleLayout
         #assign a PatternLayout to file appender
         log4j.appender.file.layout=org.apache.log4j.PatternLayout
         log4j.appender.file.layout.ConversionPattern=%p - %m%n
     
      commons-logging.properties(例子)
          ##
          org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JCategoryLog
   3.应用实例:
     package com.wes.test;
     import org.apache.commons.logging.Log;
     import org.apache.commons.logging.LogFactory;
    public abstract class BaseClass{
         /** 用于日志输出 */
         protected Log log = LogFactory.getLog(this.getClass());
    }
    这样在子类中可以直接调用log输出即可:
   public class DerivedClass extends BaseClass {
         pulbic void test() {
             //如果log4j.properties文件配置的级别<=info则可以正常输出(info/debug) 
            log.info("这是info级别的输出");   
             //如果log4j.properties文件的级别为debug则可以正常输出(debug) 
            log.debug("这是debug级别的输出");
         }
   }

 

分享到:
评论

相关推荐

    common_2018-8-6_.zip

    - **日志工具**:如Log4j、logback或Python的logging,用于记录程序运行时的信息。 3. **编程最佳实践**: - **代码风格**:遵循一定的编码规范,如Google Java Style Guide或PEP 8。 - **异常处理**:合理的...

    解读ASP.NET 5 & MVC6系列教程(9):日志框架

    在之前的.NET中,微软还没有提供过像样的日志框架,目前能用的一些框架比如Log4Net、NLog、CommonLogging使用起来多多少少都有些费劲,和java的SLF4J根本无法相比。但在新版的ASP.NET5中,可谓是牛气冲天,微软提供...

    蓝桥杯嵌入式十五届模拟1代码

    蓝桥杯嵌入式十五届模拟1代码

    1-中国各省绿色税收相关数据(2007-2022年)-社科数据.rar

    该数据集收录了2007-2022年中国各省份绿色税收相关数据,涵盖总税收、资源税、环境保护税、城市维护建设税、城镇土地使用税、车船税、耕地占用税、消费税、车辆购置税等指标。绿色税收是以保护环境、合理开发利用自然资源为目的,对特定行为或产品征收的税费,旨在通过经济手段引导企业减排降污,促进资源合理利用和可持续发展。数据包含全国31个省级行政区的年度统计,其中环境保护税自2018年开征后,与资源税等共同构成绿色税收体系,通过"多排多征、少排少征"机制推动企业环保改造。部分数据存在缺失值,但整体可直接用于区域绿色税制比较、环境政策效果评估等研究。

    joblib-0.9.0b4.tar.gz

    该资源为joblib-0.9.0b4.tar.gz,欢迎下载使用哦!

    Android开发根据外框颜色决定文字颜色以及选中颜色demo源码

    Android开发根据标签外框颜色决定字体颜色以及选中后的背景色,这样颜色不同,好看,有点难度,关键在于如何自定义控件

    blue_concrete_powder.png

    blue_concrete_powder

    Android开发仿抖音底部加载进度条demo源码

    Android开发仿抖音底部加载进度条效果,中间往外走的进度条,关键是自定义View

    3D文件硬件开发之3D文件打印,3D生成器,咸蛋超人3D打印文件,5款不同的3D文件免费下载,总有一款适合你,光之铸型:咸蛋超人3D觉醒计划

    【3D文件】硬件开发之3D文件打印,3D生成器,咸蛋超人3D打印文件,5款不同的3D文件免费下载,总有一款适合你,光之铸型:咸蛋超人3D觉醒计划 资源图片查看链接:https://blog.csdn.net/weixin_60324241/article/details/147260889?spm=1011.2415.3001.5331

    water_overlay.png

    j

    基于Springboot框架实现的学生选课管理系统(源码+数据库+万字文档)513

    基于Springboot框架实现的学生选课管理系统,包含一种角色:管理员,系统分为前台登录和后台两大模块,主要功能如下。 【前台登录】: 1. 学生登录:学生可以通过学号和密码登录系统,查看自己的选课情况、成绩等信息。 2. 教师登录:教师可以通过工号和密码登录系统,查看自己的教授课程、学生评价等信息。 【后台模块】: 1. 选课管理:管理员可以管理课程信息,包括添加、编辑、删除课程信息,设置课程容量,调整课程时间表等。 2. 教评管理:管理员可以管理学生对教师的评价,包括查看评价结果、编辑评价内容等。 3. 教评问题管理:管理员可以管理教评中的问题,包括添加、编辑、删除问题,设置问题选项等。 4. 校建管理:管理员可以管理校园建筑信息,包括添加、编辑、删除校建信息,查看校园地图等。 5. 教师管理:管理员可以管理教师信息,包括添加、编辑、删除教师信息,查看教师评价等。 6. 学生管理:管理员可以管理学生信息,包括添加、编辑、删除学生信息,查看学生选课情况等。 7. 课程管理:管理员可以管理课程信息,包括添加、编辑、删除课程信息,查看课程详情等。 8. 成绩管理:管理员可以管理学生成绩,包括录入、编辑、删除成绩,查看学生成绩单等。 9. 校园新闻:管理员可以发布校园新闻,包括添加、编辑、删除新闻,查看新闻详情等。 10. 系统管理:管理员可以管理系统的用户账号和权限,包括添加、编辑、删除用户,设置用户权限等。 二、项目技术 编程语言:Java 数据库:MySQL 项目管理工具:Maven 前端技术:HTML、Jquery、CSS、JavaScript、 后端技术:Spring、SpringMVC、MyBatis 三、运行环境 操作系统:Windows或者macOS JDK版本:最好是JDK1.8,其他版本理论上也可以 开发工具:IDEA、Ecplise

    ParagonHFS+forWin v14.0.24 x64.rar

    WINDOWS系统读取苹果分区的利器,支持HFS+及APFS分区。

    deepseek用例生成+测试工程师智能助手

    1.通过提取docx需求文档有效标题的正文内容、表格及图片OCR结果,结合动态生成的提示词进行功能测试用例生成; 2.通过提取excel、yml或json格式的接口文档,结合提示词生成接口测试用例; 3.用例以json形式预览,支持导出为md、excel、json等格式; 4.安装部署简单,只需python环境即可,安装依赖库后即可运行; 5.需替换脚本里的api-key,模型调用阿里云百炼deepseek-r1的接口;

    美食分类数据集-zip

    数据集介绍: 数据集包含五种美食图片,每种美食类型图片为1000张。

    ### 【物联网操作系统】LiteOS从入门到实战:开发环境搭建、内核解析及网络编程详解、LiteOS简介

    内容概要:本文详细介绍了LiteOS这一轻量级物联网操作系统,涵盖其特点、应用场景、开发环境搭建、内核机制、实战演练及进阶学习。LiteOS由华为开发,专为资源受限设备设计,具备轻量级、高效性、安全性和开放性等特点,适用于智能家居、工业自动化、智能穿戴和智能城市建设等领域。文章逐步讲解了Windows和Linux系统下搭建LiteOS开发环境的具体步骤,包括安装交叉编译器、HiSpark Studio、配置Python环境、下载并配置LiteOS SDK等。深入探讨了LiteOS内核的任务管理和内存管理机制,并通过Hello World程序展示了创建任务、编写代码、编译和烧录的完整流程。最后,介绍了SAL及socket编程,提供了丰富的学习资源,包括官方文档、技术论坛和开源代码库。 适合人群:具备一定编程基础,尤其是对物联网开发感兴趣的开发者,以及希望深入了解嵌入式操作系统原理的技术人员。 使用场景及目标:①学习如何在资源受限的设备上开发高效稳定的应用程序;②掌握LiteOS的任务管理、内存管理等核心机制;③通过实战演练和进阶学习,提高物联网设备的网络通信能力,如使用SAL及socket编程实现设备与服务器之间的TCP通信。 其他说明:本文不仅提供了理论知识,还结合具体代码示例和实际操作步骤,帮助读者更好地理解和应用LiteOS。物联网技术正处于快速发展阶段,掌握LiteOS开发技能将为开发者在智能家居、工业自动化、智能穿戴等领域提供强大的竞争力。

    weathered_copper_door_bottom.png

    j

    有轨装车机机行走机构设计分析.rar

    有轨装车机机行走机构设计分析.rar

    h5py-3.13.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl

    该资源为h5py-3.13.0-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl,欢迎下载使用哦!

    black_stained_glass.png

    black_stained_glass

    macOS剪辑三剑客Final Cut Pro 11.1附下载

    macOS剪辑三剑客Final Cut Pro 11.1附下载

Global site tag (gtag.js) - Google Analytics