转自:http://zochen.iteye.com/blog/616151

简单的实现了下利用JDK中类java.util.logging.Logger来记录日志。主要在于仿照log4j方式用配置文件来配置日志的输出。网络上关于如何使用java.util.logging.Logger的文章很多,但是没有完整的如何通过配置配置文件来达到控制日志输出的资料。本文的目的在于此,欢迎拍砖。 
  上码。。。

1.首先封装了个LogManager。该类的主要作用就是static块中的代码,意在读取properties文件,初始化日志属性。

  1. import java.io.IOException;
  2. import java.io.InputStream;
  3. import java.util.logging.Logger;
  4. public class LogManager {
  5. // 初始化LogManager
  6. static {
  7. // 读取配置文件  (这边也可以使用文件流)
  8. ClassLoader cl = LogManager.class.getClassLoader();
  9. InputStream inputStream = null;
  10. if (cl != null) {
  11. inputStream = cl.getResourceAsStream("log.properties");
  12. } else {
  13. inputStream = ClassLoader
  14. .getSystemResourceAsStream("log.properties");
  15. }
  16. java.util.logging.LogManager logManager = java.util.logging.LogManager
  17. .getLogManager();
  18. try {
  19. // 重新初始化日志属性并重新读取日志配置。
  20. logManager.readConfiguration(inputStream);
  21. } catch (SecurityException e) {
  22. System.err.println(e);
  23. } catch (IOException e) {
  24. System.err.println(e);
  25. }
  26. }
  27. /**
  28. * 获取日志对象
  29. * @param clazz
  30. * @return
  31. */
  32. public static Logger getLogger(Class clazz) {
  33. Logger logger = Logger
  34. .getLogger(clazz.getName());
  35. return logger;
  36. }
  37. }

2.在需要记录日志的地方,通过LogManager.getLogger()方法得到Logger对象,然后调用其记录日志的方法记录日志。这里,我记录错误堆栈信息是用的 log(Level level, String msg, Throwable thrown) 。

贴出我的properties配置文件内容,其中handlers属性一定别忘了,我就因为缺少这个属性花费了很多时间找原因。

  1. #Level的五个等级SEVERE(最高值) 、WARNING 、INFO 、CONFIG 、FINE 、FINER 、FINEST(最低值)  。这个不同于log4j
  2. #为 Handler 指定默认的级别(默认为 Level.INFO)。
  3. java.util.logging.ConsoleHandler.level=INFO
  4. # 指定要使用的 Formatter 类的名称(默认为 java.util.logging.SimpleFormatter)。
  5. java.util.logging.ConsoleHandler.formatter=java.util.logging.SimpleFormatter
  6. # 为 Handler 指定默认的级别(默认为 Level.ALL)。
  7. java.util.logging.FileHandler.level=INFO
  8. # 指定要使用的 Formatter 类的名称(默认为 java.util.logging.XMLFormatter)。
  9. java.util.logging.FileHandler.formatter=java.util.logging.SimpleFormatter
  10. # 指定要写入到任意文件的近似最大量(以字节为单位)。如果该数为 0,则没有限制(默认为无限制)。
  11. java.util.logging.FileHandler.limit=1024000
  12. # 指定有多少输出文件参与循环(默认为 1)。
  13. java.util.logging.FileHandler.count=1
  14. # 为生成的输出文件名称指定一个模式。有关细节请参见以下内容(默认为 "%h/java%u.log")。
  15. java.util.logging.FileHandler.pattern=C:/SSLog%u.log
  16. # 指定是否应该将 FileHandler 追加到任何现有文件上(默认为 false)。
  17. java.util.logging.FileHandler.append=true
  18. handlers= java.util.logging.ConsoleHandler,java.util.logging.FileHandler

这样配置后还有一个缺陷,日志文件累积到指定的大小时,将会被重新创建,也就是之前的日志信息会丢失,但是不设置大小的话会导致单个文件过大。关于这个问题还没有花时间去细究,以下这篇博文应该能解决这一问题。 
为java.util.logging自定义文件处理器及日志输出格式

通配置文件的方式控制java.util.logging.Logger日志输出的更多相关文章

  1. 【java】java自带的java.util.logging.Logger日志功能

    偶然翻阅到一篇文章,注意到Java自带的Logger日志功能,特地来细细的看一看,记录一下. 1.Java自带的日志功能,默认的配置 ①Logger的默认配置,位置在JRE安装目录下lib中的logg ...

  2. java.util.logging.Logger日志生成过程浅析 (转)

    http://www.tuicool.com/articles/vy6Zrye ****************************************** java.util.logging ...

  3. Java日志工具之java.util.logging.Logger

    今天总结下JDK自带的日志工具Logger,虽然它一直默默无闻,但有时使用它却比较方便.更详细的信息可以查看JDK API手册,本文只是简单示例入门. 创建Logger 我们可以使用Logger的工厂 ...

  4. java.util.logging.Logger 使用详解

    概述: 第1部分 创建Logger对象 第2部分 日志级别 第3部分 Handler 第4部分 Formatter 第5部分 自定义 第6部分 Logger的层次关系 参考 第1部分 创建Logger ...

  5. 2.java.util.logging.Logger使用详解

    一.java.util.logging.Logger简介 java.util.logging.Logger不是什么新鲜东西了,1.4就有了,可是因为log4j的存在,这个logger一直沉默着, 其实 ...

  6. java.util.logging.Logger使用详解 (转)

    http://lavasoft.blog.51cto.com/62575/184492/ ************************************************* java. ...

  7. java.util.logging.Logger使用具体解释

    java.util.logging.Logger不是什么新奇东西了,1.4就有了,但是由于log4j的存在,这个logger一直沉默着,事实上在一些測试性的代码中,jdk自带的logger比log4j ...

  8. java.util.logging.Logger基础

    1. 定义 java.util.logging.Logger是Java自带的日志类,可以记录程序运行中所产生的日志.通过查看所产生的日志文件,可以分析程序的运行状况,出现异常时,分析及定位异常. 2. ...

  9. Java日志介绍(1)-java.util.logging.Logger

    java.util.logging.Logger是JDK自带的日志工具,其简单实现了日志的功能,不是很完善,所以在实际应用中使用的比较少.本文直接用代码演示其使用方法,文中所使用到的软件版本:Java ...

随机推荐

  1. [LabVIEW架构]ActorFramework(二)

    前言 在上一个文章中,我们介绍了一下LabVIEW中AF的基本概念,本讲将以上一次的例子来讲解LabVIEW中的实现 正文 范例说明 假定两个人,一个作为老师,一个作为学生.学生每天早上给老师发送一封 ...

  2. FineReport——自定义登录页

    统一的接口: http://localhost:8075/WebReport/ReportServer?op=fs_load&cmd=sso&fr_username=XX&fr ...

  3. Redis 基础使用(1)

    redis 数据库的使用场景介绍 redis 是 NoSQL 数据库中的一种,特别适合解决一些使用传统关系数据库难以解决的问题,redis 作为内存数据库,如果在不合适的场合,对内存的消耗是很大的,甚 ...

  4. django “如何”系列7:错误汇报

    当你正在运行一个公共的站点的时候,你应该关掉DEBUG设置.这将使你的服务器运行的更快,同时也能预防别有用心的用户从你的错误页面看到你应用的一些详细配置信息.然而,当debug为false的时候,你将 ...

  5. Restore IP Addresses——边界条件判定

    Given a string containing only digits, restore it by returning all possible valid IP address combina ...

  6. Python安装scikit-learn包

    我先是按照网上说的下载了个setuptools,然后直接用这个工具去安装,可是安装scikit-learn包的时候确老是有错误,也不知道错误是啥,所以就不用setuptools来安装了. 我直接下载了 ...

  7. qtp录制时间控件不允许用户手动输入的解决办法

    qtp录制时间控件不允许用户手动输入的解决办法 [前面的话] 一边学习qtp,一边用自己的项目试着写代码,而遇到一个问题就会让自己卡壳很久,这次也是这样的,在写好了登录代码以后,自己就试着写第一个预订 ...

  8. macos不能打开windows samba共享问题(转载)

    转自:https://www.macx.cn/thread-2095377-1-1.html?mod=viewthread&tid=2095377&extra=page%253D1&a ...

  9. Java网络编程一

    1.InetAddress的应用 import java.util.List; import java.math.BigDecimal; import java.net.InetAddress; im ...

  10. Codeforces Round #404 (Div. 2) C 二分查找

    Codeforces Round #404 (Div. 2) 题意:对于 n and m (1 ≤ n, m ≤ 10^18)  找到 1) [n<= m] cout<<n; 2) ...