Java中的日志——Java.util.logging、log4j、commons-logging

Java中给项目程序添加log主要有三种方式,一使用JDK中的java.util.logging包,一种是log4j,一种是commons-logging。其中log4j和commons-logging都是apache软件基金会的开源项目。这三种方式的区别如下:

Java.util.logging,JDK标准库中的类,是JDK 1.4 版本之后添加的日志记录的功能包。

log4j,最强大的记录日志的方式。可以通过配置 .properties 或是 .xml 的文件, 配置日志的目的地,格式等等。

commons-logging,最综合和常见的日志记录方式,是Java中的一个日志接口,一般会与log4j一起使用。自带SimpleLog可用于日志记录。

1.Java.util.logging

【例1.1】:日志的简单使用

[java] view plaincopyprint?

  1. package lwf.log.test;
  2. import java.util.logging.Logger;
  3. public class LogTest {
  4. static String strClassName = LogTest.class.getName();
  5. static Logger logger = Logger.getLogger(strClassName);
  6. public static double division(int value1, int value2) {
  7. double result = 0;
  8. try {
  9. result = value1 / value2;
  10. } catch(ArithmeticException e) {
  11. logger.warning("除数不能为0.");
  12. e.printStackTrace();
  13. }
  14. return result;
  15. }
  16. public static void main(String[] args) {
  17. System.out.println(division(5, 0));
  18. }
  19. }

结果:

从这个例子中你会看到控制台上输出了日期时间,类名,方法名和“[warning]除数不能为0.”的信息。

Logger是Java Logging API中的一个类,Logger.getLogger方法创建了一个Logger实例。每一个Logger实例都必须有个名称,通常的做法是使用类名称定义Logger实例。

logger.warning方法用来输出日志信息,除了warning处,还有severe、info等。我们可以把【例1】再改一下,让其输出各种日志信息。

【例1.2】:日志的级别

[java] view plaincopyprint?

  1. public static double division(int value1, int value2) {
  2. double result = 0;
  3. try {
  4. result = value1 / value2;
  5. } catch(ArithmeticException e) {
  6. logger.severe("[severe]除数不能为0.");
  7. logger.warning("[warning]除数不能为0.");
  8. logger.info("[info]除数不能为0.");
  9. logger.config("[config]除数不能为0.");
  10. logger.fine("[fine]除数不能为0.");
  11. logger.finer("[finer]除数不能为0.");
  12. logger.finest("[finest]除数不能为0.");
  13. e.printStackTrace();
  14. }
  15. return result;
  16. }

结果:

Java Logging API提供了七个日志级别用来控制输出。这七个级别分别是:


级别


SEVERE


WARNING


INFO


CONFIG


FINE


FINER


FINEST


调用方法


severe()


warning()


info()


config()


fine()


finer()


finest()


含意


严重


警告


信息


配置


良好


较好


最好

但在上面的例子中我们可以看到只输出了SEVERE、WARNING、INFO三个等级的日志,并没有如我们相像中的好样输出各个级别的日志信息。这是因为默认日志输出级别的设置是info,也就是说只有info或它以上的级别被输出,它以下的级别不被输出。那如何修改这个设置呢?

日志(Log)的配制:

1.代码设置

使用setLevel();但这种方式不能改变console的级别,只能改变输出到文件的日志的级别。

2.修改logging.properties

默认的外部配置文件 是JRE中lib/logging.properties文件。你可以打开这个文件,修改以下两行为:


.level=ALL 

//...
java.util.logging.ConsoleHandler.level = ALL 

这种方式会影响jre下所有用户。

为了不影响到所有的用户,我们还可以通过LogManager的readConfiguration(InputStream ins)读取指定的配制文件。

【例1.3】:LogManager管理日志

[java] view plaincopyprint?

  1. package lwf.log.test;
  2. import java.io.IOException;
  3. import java.io.InputStream;
  4. import java.util.logging.FileHandler;
  5. import java.util.logging.Handler;
  6. import java.util.logging.Level;
  7. import java.util.logging.LogManager;
  8. import java.util.logging.LogRecord;
  9. import java.util.logging.Logger;
  10. import java.util.logging.SimpleFormatter;
  11. public class LogTest {
  12. static String strClassName = LogTest.class.getName();
  13. static Logger logger = Logger.getLogger(strClassName);
  14. static LogManager logManager = LogManager.getLogManager();
  15. static {
  16. InputStream inputStream = null;
  17. try {
  18. //读取配制文件
  19. inputStream = LogTest.class.getClassLoader().getResourceAsStream("log.properties");
  20. logManager.readConfiguration(inputStream);
  21. //添加Logger
  22. logManager.addLogger(logger);
  23. } catch (SecurityException e) {
  24. e.printStackTrace();
  25. } catch (IOException e) {
  26. e.printStackTrace();
  27. }
  28. }
  29. public static double division(int value1, int value2) {
  30. double result = 0;
  31. try {
  32. result = value1 / value2;
  33. } catch(ArithmeticException e) {
  34. logger.severe("[severe]除数不能为0.");
  35. logger.warning("[warning]除数不能为0.");
  36. logger.info("[info]除数不能为0.");
  37. logger.config("[config]除数不能为0.");
  38. logger.fine("[fine]除数不能为0.");
  39. logger.finer("[finer]除数不能为0.");
  40. logger.finest("[finest]除数不能为0.");
  41. e.printStackTrace();
  42. }
  43. return result;
  44. }
  45. public static void main(String[] args) {
  46. System.out.println(division(5, 0));
  47. }
  48. }

log.properties:


# "handlers" specifies a comma separated list of log Handler

#handlers= java.util.logging.ConsoleHandler

handlers= java.util.logging.FileHandler

# Default logging level.

.level= CONFIG

# default file output is in "E:\Test" directory.

java.util.logging.FileHandler.pattern = E:/Test/Log%u.log

java.util.logging.FileHandler.limit = 50000

java.util.logging.FileHandler.count = 1

java.util.logging.FileHandler.formatter = java.util.logging.SimpleFormatter

# Limit the message that are printed on the console to CONFIG and above.

java.util.logging.ConsoleHandler.level = CONFIG

java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter

# Facility specific properties.Provides extra control for each logger.

# For example, set the com.xyz.foo logger to only log SEVERE messages:

com.xyz.foo.level = SEVERE

这样,用户就可以自己定义配制文件了。在E:\Test下可以看到输出的日志文件Log0.log

java.util.logging包中类的关系图如下:

参考文章:

http://blog.csdn.net/dl88250/article/details/1843813

2.log4j

1.项目串导入log4j的jar包

如Eclipse下项目名右键,Build Path\Add Libraries,添加一组用户自己的jar包。项目结构如下:

2.修改log4j的配制文件,设置日志输出的级别、格式等

log4j的log有5个级别:FATAL(严重的 )、ERROR(错误 )、WARN(警告)、INFO(信息)、DEBUG(调试 )。

3.在项目代码中适当添加日志。

【例2.1】

log4j.properties:


#set log level: show debug, info, error

log4j.rootLogger=DEBUG, A1

# A1 is set to be a ConsoleAppender which outputs to System.out.

#log4j.appender.A1=org.apache.log4j.ConsoleAppender

log4j.appender.A1=org.apache.log4j.FileAppender

# A1 uses PatternLayout.

log4j.appender.A1.layout=org.apache.log4j.PatternLayout

#out

log4j.appender.A1.File=E:/test/log4j.log

# set log output format‘s style

log4j.appender.A1.layout=org.apache.log4j.TTCCLayout

代码:

[java] view plaincopyprint?

  1. package lwf.log.test;
  2. import org.apache.log4j.Logger;
  3. public class Log4jTest {
  4. private static Logger logger = Logger.getLogger(Log4jTest.class);
  5. public static void main(String[] args) {
  6. System.out.println("This is log4j test.");
  7. // 记录debug级别的信息
  8. logger.debug("This is debug message.");
  9. // 记录info级别的信息
  10. logger.info("This is info message.");
  11. // 记录error级别的信息
  12. logger.error("This is error message.");
  13. }
  14. }

log4j的使用和配制另参见:http://blog.csdn.net/luoweifu/article/details/43638495

3.commons-logging

commons-logging提供的是一个日志(Log)接口(interface),是为那些需要建立在不同环境下使用不同日志架构的组件或库的开发者创建的,其中包括Apache Log4j以及Java log的日志架构。把日志信息抽象成commons-logging的Log接口,并由commons-logging在运行时决定使用哪种日志架构。因为Log4j的强大功能,commons-logging一般会和Log4j一起使用,这几乎成为了Java日志的标准工具。

commons-logging有两个基本的抽象类:Log(基本记录器)和LogFactory(负责创建Log实例)。当commons-logging.jar被加入到CLASSPATH(通常将commons-logging.jar放在web project下的WebContent\WEB-INF\lib目录中)之后,它会合理地猜测你想用的日志工具,然后进行自我设置,用户根本不需要做任何设置。默认的LogFactory是按照下列的步骤去发现并决定那个日志工具将被使用的(按照顺序,寻找过程会在找到第一个工具时中止,这个顺序非常重要):

00001. 寻找当前factory中名叫org.apache.commons.logging.Log配置属性的值

00002. 寻找系统中属性中名叫org.apache.commons.logging.Log的值

00003. 如果应用程序的classpath中有log4j,则使用相关的包装(wrapper)类(Log4JLogger)

00004. 如果应用程序运行在jdk1.4的系统中,使用相关的包装类(Jdk14Logger)

00005. 使用简易日志包装类(SimpleLog)

commons-logging与log4j的配合使用:

项目目录结构:

common-logging.properties:


#use commons-logging default SimpleLog

# org.apache.commons.logging.Log=org.apache.commons.logging.impl.SimpleLog

#use log4j

org.apache.commons.logging.Log=org.apache.commons.logging.impl.Log4JCategoryLog

#JDK1.4 Logger

#org.apache.commons.logging.Log=org.apache.commons.logging.impl.Jdk14Logger

代码:

[cpp] view plaincopyprint?

  1. package lwf.log.test;
  2. import org.apache.log4j.Logger;
  3. public class Log4jTest {
  4. private static Logger logger = Logger.getLogger(Log4jTest.class);
  5. public static void main(String[] args) {
  6. System.out.println("This is log4j test.");
  7. // 记录debug级别的信息
  8. logger.debug("This is debug message.");
  9. // 记录info级别的信息
  10. logger.info("This is info message.");
  11. // 记录error级别的信息
  12. logger.error("This is error message.");
  13. }
  14. }

参考:

http://www.cnblogs.com/xwdreamer/archive/2011/12/28/2304598.html

http://shift8.iteye.com/blog/1316802

如果您有什么疑惑和想法,请在评论处给予反馈,您的反馈就是最好的测评师!由于本人技术和能力有限,如果本博文有错误或不足之处,敬请谅解并给出您宝贵的建议!

========================编程思想系列文章回顾========================

编程思想之异常处理

编程思想之正则表达式

编程思想之迭代器

编程思想之递归

编程思想之回调

时间: 2024-12-28 10:16:16

Java中的日志——Java.util.logging、log4j、commons-logging的相关文章

java中的日志打印

java中的日志打印: 日志工具类: 1 #获取日志 INFO:表示获取日志的等级 A1:表示日志存器,可以自定义名称 2 #===DEBUG INFO 3 log4j.rootLogger=DEBUG,A1,A2,A3 4 5 6 7 ########################控制台日志#################################### 8 9 #定义日志A1存放器 10 11 log4j.appender.A1=org.apache.log4j.ConsoleAp

Java中数组操作 java.util.Arrays 类常用方法的使用

任何一门编程语言,数组都是最重要和常用的数据结构之一,但不同的语言对数组的构造与处理是不尽相同的. Java中提供了java.util.Arrays 类能方便地操作数组,并且它提供的所有方法都是静态的.下面介绍一下Arrays类最常用的几个方法. 1.  数组排序 Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能. 2.  数组转换为字符串 Arrays提供了一个toString方法,可以直接把一个数组转换为字符串,这样可以方便观察数组里的元素. //来源:公众号[时光与

java中的日志组件-log4j

1.为什么使用日志组件 Log4J是Apache的一个开放源代码项目,它是一个日志操作包,通过使用Log4J,可以指定日志信息输出的目的地,如控制台.文件.CUI组件.NT的事件记录器:还可以控制每一条日志输出格式.此外,通过定义日志信息的级别,能够非常细致地控制日志的输出,最令人感兴趣的是,这些功能可以通过一个配置文件来灵活进行配置,而不需要修改应程序代码. 在应用程序中输出日志有3个目的: 监视代码中变量的变化情况,把数据周期性记录到文件中供其他应用进行统计分析工作: 跟踪代码运行时轨迹,作

java中开源日志记录工具log4j

日志:除了能记录异常信息,还可以记录程序正常运行时的关键信息. 使用log4j来进行日志文件记录经典步骤: 001.在项目中创建一个lib文件夹,然后将下载好的jar包copy到该文件夹下 002.对已经copy过来的jar包,点击右键,然后执行下图操作, 项目中就会多出一个引入外部Library的项目 003.在src目录下创建一个名称为log4j.properties文件 004.编写,粘贴已经写好的配置文件内容,编码方式可以做下修正.对配置文件点击右键→属性→other→utf-8,然后应

Java中的日志管理

日志是应用程序运行中不可缺少的一部分,JAVA中有很多已经成熟的方案,尽管记录日志是应用开发中并不可少的功能,在 JDK 的最初版本中并不包含日志记录相关的 API 和实现.相关的 API(java.util.logging 包,JUL)和实现,直到 JDK 1.4 才被加入.因此在日志记录这一个领域,社区贡献了很多开源的实现.其中比较流行的包括 log4j 及其后继者 logback.除了真正的日志记录实现之外,还有一类与日志记录相关的封装 API,如 Apache Commons Loggi

JAVA中自定义日志输出到指定文件

虽然JAVA日志包提供的功能已经很方便,但是假如我们有新的需求如:将日志文件保存到我们希望的位置并在日志文件名中添加日期且保存指定时间内的日志文件:按照自己希望的格式输出日志内容.对于这些需求我们只要扩展java.util.logging.StreamHandler(Handler的子类),java.util.logging.Formatter创建自定义的处理器及格式化器即可以实现.下面是个例子,它分别创建了Handler及Formatter的子类,以便实现将日志文件保存到我们需要的位置,及在日

Java中的日志框架

需求 使用日志框架有三点需求: 1.期望日志能保存在文件中,方便时候排错. 2.开发环境的日志记录会更多方便调试. 3.生产环境需要记录重要的信息.   Log4j 可用于普通maven项目,也可以用于springboot项目. Log4j提供了简单的API调用,强大的日志格式定义以及灵活的扩展性. 可以自定义Appender来满足日志输出的需求. 日志级别 从低到高 DEBUG INFO WARN ERROR FATAL pom依赖 <!-- https://mvnrepository.com

java中添加日志

在简单的项目中添加日志: 首先导入2个jar包 commons-logging-1.1.1.jar log4j-1.2.15.jar 然后在项目的src目录下创建log的配置文件 log4j.properties内容如下: ## 定义 DEBUG 优先级, R 为日志输出目的的 #log4j.rootLogger= DEBUG,R ## 设置日志输出类型 , 为文件类型 #log4j.appender.R= org.apache.log4j.FileAppender ## 设置日志文件名 log

Java中SQL DATE和 UTIL DATE 的相互转换

public String getStringtime (java.sql.Date sdate ){ java.util.Date date = new java.util.Date(sdate.getTime()); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String time =sdf.format(date); return time; } public java.sql.Date getSdate