`
endual
  • 浏览: 3561008 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

如何在项目中用好log4J写项目日志(转)

 
阅读更多

2008-04-18



一般的系统对程序的调试信息只进行了简单的粗放处理,将这些信息直接用System.out.println()语句输出到控制台中。由于在调度过程中程序员为了能够跟踪程序的运行情况往往将大量信息输出到控制台,而在调度成功后没有相应地将这些信息屏蔽掉,在程序部署运行后,往往一个简单的业务功能调用也会输出大容量的过程调度信息,一方面造成了大量IO的读写,占用硬盘空间,另一方面则因为日志量大,很难查找到运行期有用的日志信息。

程序异常,资源释放操作失败这些信息是发现程序问题,定位出错点的信息依据,得不到这些信息将导致程序错误被屏蔽,要想使问题浮出水面程序必须能够提供详细而简洁的日志信息。

?log4J是为java语言量身定做的一个日志模块,用统一的接口写日志,通过配置文件信息控制日志信息的输出格式、目的及输出级别(指定输出级别后,只有比输出级别更高的日志会被输出)。可以在不更改程序输出日志的情况下方便日志输出的控制,为日志的操作提供了很大的灵活性。
2 log4J的基本操作
2.1写日志的API

 log4J将日志分为5个级别,从低到高分别是DEBUG,INFO,WARN,ERROR,FATAL,相应地log4J为记录这5个级别提供了5个方法,它们分别是:

   public void debug(Object obj)

   public void info(Object obj)

   public void warn(Object obj)

   public void error(Object obj)

   public void fatal(Object obj)

同时每个方法还对应一个带Throwable入参的重载函数,用于将异常一并记录到日志中:

   public void debug(Object obj,Throwable ex)

   public void info(Object obj,Throwable ex)

   public void warn(Object obj,Throwable ex)

   public void error(Object obj,Throwable ex)

   public void fatal(Object obj,Throwable ex)

5个级别记录信息的重要性依次提升,下面就每个记录方法对应的应用场合举例如下:
2.1.1 写日志API的使用示例

     在程序中如何恰当级别的日志记录API记录日志信息是非常重要的,一般的我们将信息以其重要性调用将其划分为5个级别,分别调用相应的API来记录,我们以一个查询数据库的代码段来说明各级别的划分:

Java代码  收藏代码
  1. Connection conn = null;  
  2.     String sqlStr = "select * from table1 where a=’"+a+"’";  
  3.     // 测试变量是否正确,在调度时查看,以后不会用  
  4.     logger.debug("sqlStr字串为:"+sqlStr);  
  5.     // ...  
  6.     try  
  7.     {  
  8.     conn = DBBean.getConnection();  
  9.     Statement stat = conn.createStatement();  
  10.     ResultSet rs = stat.executeQuery(sqlStr);  
  11.     if(rs.next())  
  12.     {  
  13.          logger.info("有记录");  
  14.                // 查看程序运行中的信息,反映程序及配置信息的情况  
  15.     }  
  16.     else  
  17.     {  
  18.            logger.warn("因配置要求至少要有一条记录,请核对配置信息。");  
  19.           // 假设配置信息要求一条配置记录,当找不到记录时应该警告,  
  20.                // 以并更改配置  
  21.     }  
  22.     }catch(SQLException e)  
  23.     {  
  24.               logger.error("数据查询时发生异常",e);  
  25.              // 发生了查询异常,可能是sqlStr语句的语法错误造成的  
  26.     }  
  27.     finally  
  28.     {  
  29.     try  
  30.     {  
  31.      if(conn != null)  
  32.     {  
  33.       conn.close();  
  34.        conn = null;  
  35.     }  
  36.     }  
  37.     catch(SQLException e)  
  38.     {  
  39.             logger.warn("数据连接无法关闭,连接将无法释放",e);  
  40.             // 数据连接无法关闭将导致资源泄漏,可能是系统原因产生的  
  41.                // 如果持续产生这个问题,开发人员需要查明原因,  
  42.                // 否则系统将因数据连接资源无法释放而崩溃  
  43.     }  
  44.     }  

分享到:
评论

相关推荐

    log4j配置和加载方法

    本文将深入解析log4j的配置与加载机制,帮助开发者更好地理解和应用log4j。 #### Log4j配置文件格式 Log4j支持多种配置文件格式,包括`.properties`和`.xml`。两种格式在功能上并无本质区别,选择哪种取决于个人或...

    log4j日志记录

    ### log4j日志记录详解 #### 一、log4j简介 Log4j是由Apache组织提供的一个开源项目,主要用于实现日志记录功能。在现代软件开发中,特别是在企业级应用开发领域,日志记录是必不可少的一个环节。它能够帮助开发者...

    log4j日志的数据库管理

    ### log4j日志的数据库管理 在现代软件开发中,日志记录是维护系统稳定性和性能的关键环节。Log4j作为Apache旗下的一款开源日志框架,被广泛应用于Java应用程序中,用于收集、管理和分析应用运行时产生的各种日志...

    Tomcat使用Log4j输出catalina.out日志

    日志格式和项目中用log4j打出来的不一致,不利于解析。 从tomcat官网(https://tomcat.apache.org/tomcat-7.0-doc/logging.html)上找了下,修改一些配置、替换扩展包即可使用log4j输出catalian.out。 在$CATALINA_...

    Spring Secruity 项目中用到的包整理

    4. `com.springsource.org.apache.log4j-1.2.15.jar`: 这是Apache Log4j的日志库,Spring Security和其他许多框架一样,使用Log4j进行日志记录,帮助开发者调试和跟踪安全相关的事件。 5. `org.springframework.web...

    读写日志文件

    2. Java:`java.util.logging`或第三方库如Log4j、Logback,都提供了多线程日志处理能力。 3. C++:可以使用Glog或spdlog,它们都支持多线程环境下的日志处理。 六、日志存储与检索 1. 文件存储:简单易用,但查询...

    Apache log4cxx在C++多进程多线程下的使用.pdf

    是著名的日志记录组件 log4j 的 C++ 移植版,用于为 C++ 程序提供日志功能,以便开发者对目标程序进行调试和审计。当前的最新版本为 0.10.0。 Apache log4cxx 框架组成 Apache Log4cxx 有三个关键组件,它们是 ...

    ssm一个简单项目所需的xml配置文件

    ssm一个简单项目所需的xml配置文件,spring+springmvc+mybatis框架中用到...项目中还会用到两个资源属性文件jdbc.properties和log4j.properties.一个是关于jdbc的配置,提取出来方便以后的修改.另一个是日志文件的配置.

    java集合框架SSH项目所需要的额jar包

    - `slf4j-api.jar` 和 `slf4j-log4j12.jar`:简单日志门面(SLF4J)与Log4j的桥接器。 - `cglib-nodep.jar`:Spring AOP中用到的代码生成库。 - `asm*.jar`:用于运行时字节码操作的库,可能在Hibernate或Spring...

    Mina2.0完全剖析,完全自学手册

    - **slf4j-api-1.5.2.jar** 和 **slf4j-log4j12-1.5.2.jar**:用于日志记录。 - **log4j-1.2.14.jar**:Log4j的版本依赖于SLF4J的实现。 确保下载并配置这些库文件后,即可开始编写代码。 ##### 第二步. 工程创建...

    mybatis用到的jar包

    4. **slf4j-api-x.x.x.jar** 和 **slf4j-log4j12-x.x.x.jar**:Simple Logging Facade for Java (SLF4J) 是一个日志门面接口,允许你在运行时选择不同的日志实现。SLF4J-api提供了一组API,而slf4j-log4j12是SLF4J与...

    idea中用到的lib下的jar包

    7. **commons-logging-1.1.1.jar**:Apache Commons Logging是一个日志抽象层,允许开发者选择底层的日志实现,如log4j、java.util.logging等,而无需更改代码。 8. **commons-fileupload-1.2.2.jar**:Apache ...

    JAVA中用axis编写webService时所用jar包

    5. **其他依赖库**:如log4j.jar用于日志记录,wsdl4j.jar用于处理WSDL文档,还有commons-logging.jar、commons-codec.jar、commons-discovery.jar等Apache Commons库,它们提供了各种实用工具和功能。 6. **...

    自己的Java工具类库 + 主体项目测试.zip

    工具类库可能会集成常见的日志框架(如Log4j、SLF4J或Java内置的日志系统),并提供统一的API。 在"主体项目测试"部分,可能包含对这些工具类库的实际应用和验证,通过单元测试或集成测试确保其正确性和性能。测试...

    Hibernate入门之自己写的小例子的总结

    解决方法是删除或在工程的classes目录下放置log4j的配置文件`log4j.properties`。 通过这个简单的例子,你将了解Hibernate的基本用法,包括如何定义实体类,配置映射文件,以及如何设置和使用Hibernate的配置。随着...

    java中用URLConnection类post方式提交表单.pdf

    在我们的示例代码中,我们还使用了 Log4j 来记录日志,以便于调试和错误处理。 下面是该技术的一些关键点: * 使用 URLConnection 类可以实现 HTTP 请求代理。 * 使用 HttpURLConnection 对象可以发送 GET 和 POST...

    WEB开发常用JAR包

    3. **LOG4J**:Log4j是Apache的一个开源项目,它是Java的日志工具,提供了灵活且强大的日志记录功能。通过配置,可以控制日志信息输出的级别,选择输出目的地(如控制台、文件、数据库等),并且可以自定义日志格式...

    mybatis +spring整合jar 包

    7. **slf4j-log4j12-1.7.25.jar**:Simple Logging Facade for Java (SLF4J)的日志适配器,允许将SLF4J与log4j结合使用。 8. **ant-launcher-1.9.6.jar**:Apache Ant的启动器,可能在构建过程中用到。 9. **slf4j...

    C++ 资源大全地址:标准库、Web应用框架、人工智能、数据库、图片处理、机器学习、日志、代码分析地址.zip

    2. Log4cpp:类似Java的Log4j,提供灵活的日志配置和输出。 八、代码分析 用于代码分析和静态检查的工具: 1. Clang-Tidy:基于Clang的静态代码分析工具。 2. Coverity:商业静态分析工具,查找潜在错误和安全漏洞...

Global site tag (gtag.js) - Google Analytics