一.java.util.logging.Logger简介

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

其实在一些测试性的代码中,jdk自带的logger比log4j更方便。

二.Logger的级别

比log4j的级别详细,全部定义在java.util.logging.Level里面。

各级别按降序排列如下:

· SEVERE(最高值)

· WARNING

· INFO

· CONFIG

· FINE

· FINER

· FINEST(最低值)

此外,还有一个级别 OFF,可用来关闭日志记录,使用级别 ALL 启用所有消息的日志记录。

logger默认的级别是INFO,比INFO更低的日志将不显示。

Logger的默认级别定义是在jre安装目录的lib下面。

# Limit the message that are printed on the console to INFO and above.
java.util.logging.ConsoleHandler.level = INFO

三.简单的实例代码

package com.my.utils;

import java.io.IOException;
import java.util.logging.ConsoleHandler;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger; public class LoggerLog {
public static void main(String[] args) {
//create logger
Logger logger = Logger.getLogger("LoggerLog");
logger.setLevel(Level.INFO); //create console handler
ConsoleHandler handler = new ConsoleHandler();
handler.setLevel(Level.ALL); //add console handler to logger
logger.addHandler(handler); try {
//add fileHandler
FileHandler fileHandler = new FileHandler("D:\\java\\test\\test.txt");
fileHandler.setLevel(Level.ALL); //add fileHandler to logger
logger.addHandler(fileHandler);
} catch (SecurityException | IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} logger.info("Start");
logger.info("Running");
logger.info("End"); } }

这时候你会发现 "Start" "Running" "End" 各在控制台上打印了两遍,是因为log输出了一次, ConsoleHandler输出了一次

在 new fileHandler 时,在文件后加参数可以控制是追加还是新建log文件。

FileHandler fh = new FileHandler(path,true).

Handler 对象从 Logger 中获取日志信息,并将这些信息导出。例如,它可将这些信息写入控制台或文件中,也可以将这些信息发送到网络日志服务中,或将其转发到操作系统日志中。
可通过执行 setLevel(Level.OFF) 来禁用 Handler,并可通过执行适当级别的 setLevel 来重新启用。
Handler 类通常使用 LogManager 属性来设置 Handler 的 Filter、Formatter 和 Level 的默认值。

检查D盘的输出日志如下:

<?xml version="1.0" encoding="GBK" standalone="no"?>
<!DOCTYPE log SYSTEM "logger.dtd">
<log>
<record>
<date>2018-03-25T20:35:42</date>
<millis>1521981342189</millis>
<sequence>0</sequence>
<logger>LoggerLog</logger>
<level>INFO</level>
<class>com.my.utils.LoggerLog</class>
<method>main</method>
<thread>1</thread>
<message>Start</message>
</record>
<record>
<date>2018-03-25T20:35:42</date>
<millis>1521981342292</millis>
<sequence>1</sequence>
<logger>LoggerLog</logger>
<level>INFO</level>
<class>com.my.utils.LoggerLog</class>
<method>main</method>
<thread>1</thread>
<message>Running</message>
</record>
<record>
<date>2018-03-25T20:35:42</date>
<millis>1521981342298</millis>
<sequence>2</sequence>
<logger>LoggerLog</logger>
<level>INFO</level>
<class>com.my.utils.LoggerLog</class>
<method>main</method>
<thread>1</thread>
<message>End</message>
</record>
</log>

可见,默认的日志方式是xml格式,我们使用日志就是为了能够清晰的看到操作的相关信息而这种格式有点多,乱所以我们要自定义logger的格式。需要用Formatter来定义。

四.定义输出日志的Formatter

package com.my.utils;

import java.text.SimpleDateFormat;
import java.util.logging.Formatter;
import java.util.logging.LogRecord; public class MyFormat extends Formatter { @Override
public String format(LogRecord log) {
// TODO Auto-generated method stub
SimpleDateFormat format = new SimpleDateFormat("YYYY-MM-dd HH:mm:ss S"); return log.getLevel() + ": " + format.format(log.getMillis())+" " + log.getMessage() +"\n";
} }

然后把 Format 添加到 fileHandler 中

fileHandler.setFormatter(new MyFormat());

这时候 输出的日志文件就是比较清晰了,可以根据项目的实际需求定义合适的Format

INFO: 2018-03-25 21:03:49 791 Start
INFO: 2018-03-25 21:03:49 909 Running
INFO: 2018-03-25 21:03:49 913 End

Formatter 为格式化 LogRecords 提供支持。 
一般来说,每个日志记录 Handler 都有关联的 Formatter。Formatter 接受 LogRecord,并将它转换为一个字符串。 
有些 formatter(如 XMLFormatter)需要围绕一组格式化记录来包装头部和尾部字符串。可以使用 getHeader 和 getTail 方法来获得这些字符串。

LogRecord 对象用于在日志框架和单个日志 Handler 之间传递日志请求。
LogRecord(Level level, String msg)   用给定级别和消息值构造 LogRecord。

 

2018-06-08 14:41

2019-02-14 10:41

2.java.util.logging.Logger使用详解的更多相关文章

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

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

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

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

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

    一.创建Logger对象   static Logger getLogger(String name)           为指定子系统查找或创建一个 logger. static Logger ge ...

  4. java.util.logging jdk日志详解

    jdk自带的日志,结构并不复杂,功能也能满足绝大部分功能.日志写入位置是开放的,只要继承了handler都可以接收日志的写入.handler本身依赖于LogRecord对象,该对象代表一个日志.Han ...

  5. java.util.logging.Logger基础教程

    从JDK1.4开始即引入与日志相关的类java.util.logging.Logger,但由于Log4J的存在,一直未能广泛使用.综合网上各类说法,大致认为: (1)Logger:适用于小型系统,当日 ...

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

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

  7. java.util.logging.Logger基础

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

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

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

  9. 通配置文件的方式控制java.util.logging.Logger日志输出

    转自:http://zochen.iteye.com/blog/616151 简单的实现了下利用JDK中类java.util.logging.Logger来记录日志.主要在于仿照log4j方式用配置文 ...

随机推荐

  1. 转 Caffe学习系列(5):其它常用层及参数

    本文讲解一些其它的常用层,包括:softmax_loss层,Inner Product层,accuracy层,reshape层和dropout层及其它们的参数配置. 1.softmax-loss so ...

  2. rpm检验是否被改动过

    参考原文http://vbird.dic.ksu.edu.tw/linux_basic/0520rpm_and_srpm.php#rpmmanager_verify   rpm -qVa   (当然可 ...

  3. mysql常用基础操作语法(八)~~多表查询合并结果和内连接查询【命令行模式】

    1.使用union和union all合并两个查询结果:select 字段名 from tablename1 union select 字段名 from tablename2: 注意这个操作必须保证两 ...

  4. win8.1中安装rabbitmq

    项目测试的时候,用的是项目组linux测试机上的rabbitmq,为了方便自己随时使用,便在自己的电脑win8.1上也安装了一套,安装过程如下: 一.准备erlang和rabbitmq的安装程序:   ...

  5. 嵌入式linux------ffmpeg移植 编码H264(am335x编码H264)

    [cpp] view plaincopy <pre name="code" class="cpp"><pre name="code& ...

  6. 招聘面试—关于Mysql的一点儿总结

    最近半年,作为部门的面试官之一,参加了许多次招聘面试.数据库知识,尤其是对数据的增删改查等操作是软件测试人员的基本功,是面试过程中的必考项.在这其中,有一道题,是我每次面试的必考题. 题目 以Mysq ...

  7. js判定是否为chrome,区分搜狗+360

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. Luogu 睡觉困难综合征 ([NOI2014]起床困难综合症)

    一.[NOI2014]起床困难综合症 题目描述 网址:https://daniu.luogu.org/problemnew/show/2114 大意: 有一条链,链上每一个节点包含一个位运算f 与 一 ...

  9. UOJ207:共价大爷游长沙

    题面 UOJ Sol 神题 给每个点对随机一个权值,把这两个点的权值异或上这个随机的值 用\(LCT\)维护子树信息,若子树异或和为所有点对的异或和那么就是答案 大常数代码 # include < ...

  10. SpringMVC 注解式开发

    SpringMVC的注解式开发是指,处理器是基于注解的类的开发.对于每一个定义的处理器,无需再配置文件中逐个注册,只需在代码中通过对类与方法的注解,便可完成注册.即注解替换是配置文件中对于处理器的注册 ...