JDK Logger 简介 (zhuan)
http://antlove.iteye.com/blog/1924832
*******************************************
一 简述
java.util.logging是JDK自带的日志记录包。
默认情况下,JDK的LogManager会在JRE目录下的"lib/logging.properties"这个文件中读取配置。
JDK的日志包涉及handler,formatter,level
| 名词 | 描述 |
| handler |
将日志信息记录到指定的流之中,可能是控制台或者是一个文件或者是任意存储区域。 常用实现类 ConsoleHandler, FileHandler, SocketHandler |
| formatter | 日志信息格式化类。常用实现类 SimpleFormatter, XMLFormatter |
| level |
日志记录级别。 SEVERE(最高值) 、WARNING 、INFO 、CONFIG 、FINE 、FINER 、FINEST(最低值) ALL(记录所有信息) OFF(不记录任何级别信息) |
二 简单Demo
MySimpleFormatter.java
- package logging.formatter;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import java.util.logging.Level;
- import java.util.logging.LogRecord;
- import java.util.logging.SimpleFormatter;
- public class MySimpleFormatter extends SimpleFormatter{
- private SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- private StringBuilder sb = new StringBuilder();
- @Override
- public synchronized String format(LogRecord record)
- {
- Level level=record.getLevel();
- String time=sdf.format(new Date(record.getMillis()));
- String loggerName=record.getLoggerName();
- String message=record.getMessage();
- this.sb.append("[").append(level).append("]");
- this.sb.append(" ").append(time);
- this.sb.append(" ").append(loggerName);
- this.sb.append(" :").append(message);
- this.sb.append("\n");
- return sb.toString();
- }
- }
DefaultStreamHandler.java
- package logging.handler;
- import java.io.OutputStream;
- import java.util.logging.StreamHandler;
- public class DefaultStreamHandler extends StreamHandler {
- @Override
- public synchronized void setOutputStream(OutputStream out)
- throws SecurityException {
- super.setOutputStream(out);
- }
- }
CustomLogManager.java
- package logging.util;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.logging.ConsoleHandler;
- import java.util.logging.FileHandler;
- import java.util.logging.Level;
- import java.util.logging.LogManager;
- import java.util.logging.Logger;
- import logging.formatter.MySimpleFormatter;
- import logging.handler.DefaultStreamHandler;
- public class CustomLogManager{
- static{
- LogManager.getLogManager().reset(); // reset the log manager
- }
- // read the log configuration from outside property file
- public static void resetFromPropertyFile(String filePath){
- LogManager logManager = LogManager.getLogManager();
- InputStream inputStream = CustomLogManagerEditor.class.getClassLoader().getResourceAsStream(filePath);
- try {
- logManager.readConfiguration(inputStream);
- } catch (Exception e) {
- throw new RuntimeException("reload log configuration fail: "+e.toString());
- }
- }
- public static Logger getLogger(String name){
- Logger logger=Logger.getLogger(name);
- logger.setLevel(Level.ALL);
- // add console handler
- ConsoleHandler consoleHandler=new ConsoleHandler();
- consoleHandler.setLevel(Level.FINE);
- consoleHandler.setFormatter(new MySimpleFormatter());
- logger.addHandler(consoleHandler);
- // add file handler
- FileHandler fileHandler=null;
- try {
- fileHandler = new FileHandler("log.log",true);
- fileHandler.setLevel(Level.FINE);
- fileHandler.setFormatter(new MySimpleFormatter());
- logger.addHandler(fileHandler);
- } catch (SecurityException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- // add default stream handler
- DefaultStreamHandler defaultStreamHandler = new DefaultStreamHandler();
- defaultStreamHandler.setLevel(Level.ALL);
- defaultStreamHandler.setFormatter(new MySimpleFormatter());
- defaultStreamHandler.setOutputStream(System.out);
- logger.addHandler(defaultStreamHandler);
- return logger;
- }
- }
logging.properties
- #Level的五个等级SEVERE(最高值) 、WARNING 、INFO 、CONFIG 、FINE 、FINER 、FINEST(最低值) 。这个不同于log4j
- #指定默认logger级别
- .level= ALL
- #为 Handler 指定默认的级别(默认为 Level.INFO)。
- java.util.logging.ConsoleHandler.level=FINE
- # 指定要使用的 Formatter 类的名称(默认为 java.util.logging.SimpleFormatter)。
- java.util.logging.ConsoleHandler.formatter=logging.formatter.MySimpleFormatter
- # 为 Handler 指定默认的级别(默认为 Level.ALL)。
- java.util.logging.FileHandler.level=ALL
- # 指定要使用的 Formatter 类的名称(默认为 java.util.logging.XMLFormatter)。
- java.util.logging.FileHandler.formatter=java.util.logging.SimpleFormatter
- # 指定要写入到任意文件的近似最大量(以字节为单位)。如果该数为 0,则没有限制(默认为无限制)。
- java.util.logging.FileHandler.limit=1024000
- # 指定有多少输出文件参与循环(默认为 1)。
- java.util.logging.FileHandler.count=1
- # 为生成的输出文件名称指定一个模式。有关细节请参见以下内容(默认为 "%h/java%u.log")。
- java.util.logging.FileHandler.pattern=u.log
- # 指定是否应该将 FileHandler 追加到任何现有文件上(默认为 false)。
- java.util.logging.FileHandler.append=true
- handlers= java.util.logging.ConsoleHandler,java.util.logging.FileHandler
测试类
Main.java
- package logging;
- import java.io.IOException;
- import java.util.logging.Logger;
- import logging.util.CustomLogManager;
- public class Main {
- public static void main(String[] args) throws SecurityException, IOException {
- // CustomLogManager.resetFromPropertyFile("logging/logging.properties");
- // Logger logger=Logger.getLogger(Main.class.getName());
- Logger logger=CustomLogManager.getLogger(Main.class.getName());
- logger.fine("warning test!");
- }
- }
Note:
CustomLogManagerEditor.getLogger返回的logger拥有三个handler,所以记录日志信息的时候,日志信息会被存储到三个区域【log.log,System.out,System.err】。
当启用CustomLogManagerEditor.resetFromPropertyFile("logging/logging.properties");时,日志信息会被记录到控制台,以及u.log文件。
如果即调用CustomLogManagerEditor.resetFromPropertyFile("logging/logging.properties");又通过CustomLogManagerEditor.getLogger返回的logger记录日志,因为logger有5个handler,所以日志信息会被记录到4个区域【u.log,log.log,System.out,System.err】 其中在System.err中会记录2次。
JDK Logger 简介 (zhuan)的更多相关文章
- JDK的简介,卸载和安装过程
JDK的简介,卸载和安装过程 JDK JRE JVM JDK:Java Development Kit JRE:Java Runtime Environment JVM:Java Virtual Ma ...
- 3-30 flash(api),rescue_from(); logger简介
ActionDispatch::Flash < Objec pass temporary primitive-types (String, Array, Hash) between action ...
- Lucene:基于Java的全文检索引擎简介 (zhuan)
http://www.chedong.com/tech/lucene.html ********************************************** Lucene是一个基于Ja ...
- 2.java.util.logging.Logger使用详解
一.java.util.logging.Logger简介 java.util.logging.Logger不是什么新鲜东西了,1.4就有了,可是因为log4j的存在,这个logger一直沉默着, 其实 ...
- JDK自带的日志Logging
OK,现在我们来研究下JDK自带的日志Logger. 从jdk1.4起,JDK开始自带一套日志系统.JDK Logger最大的优点就是不需要任何类库的支持,只要有Java的运行环境就可以使用. 相对于 ...
- logback中logger详解
前言 logback实践笔记 上一篇主要对root进行了实践总结,现在基于上一篇中的springboot代码环境对logback.xml中的logger来进行实践和自己遇到的坑. logger简介 ...
- Java日志 (zhuan)
http://www.cnblogs.com/bird-li/p/4696662.html ************************************************* 日志对于 ...
- 日志框架--(二)JDK Logging
前言 从jdk1.4起,JDK开始自带一套日志系统.JDK Logger最大的优点就是不需要任何类库的支持,只要有Java的运行环境就可以使用.相对于其他的日志框架,JDK自带的日志可谓是鸡肋,无论易 ...
- Logback相关知识汇总
例如:%-4relative 表示,将输出从程序启动到创建日志记录的时间 进行左对齐 且最小宽度为4格式修饰符,与转换符共同使用:可选的格式修饰符位于“%”和转换符之间.第一个可选修饰符是左对齐 标志 ...
随机推荐
- 解决org/sonarsource/scanner/maven/SonarQubeMojo : Unsupported major.minor version 52.0
ide jdk 版本换成对应的 如:sonarqube-6.3 --> jdk1.8
- java 复制Map对象(深拷贝与浅拷贝)
java 复制Map对象(深拷贝与浅拷贝) CreationTime--2018年6月4日10点00分 Author:Marydon 1.深拷贝与浅拷贝 浅拷贝:只复制对象的引用,两个引用仍然指向 ...
- Centos定时执行python脚本
其实就是linux的定时任务.老记不住参数,这次写下来,省着老百度.本文没有技术含量,请大家不要吐槽. ================================================ ...
- mysql中innodb和myisam的区别
InnoDB和MyISAM是很多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,5.7之后就不一样了 1.事务和外键 InnoDB具有事务,支持4个事务隔离级别,回滚,崩溃修复能力和多版 ...
- C-边界对齐
转自:http://blog.csdn.net/b_h_l/article/details/7738197 许 多实际的计算机系统对基本类型数据在内存中存放的位置有限制,它们会要求这些数据的首地址的值 ...
- HDUOJ---------Kia's Calculation
Kia's Calculation Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- Python 的 if __name__ == '__main__'
Python 文件 最后部分会有: if __name__ == '__main__': TestRLSO()……………… 1)首先,这是一个判断语句. 表示执行的是此代码所在的文件.如果这个文件是作 ...
- 【LeetCode】107. Binary Tree Level Order Traversal II (2 solutions)
Binary Tree Level Order Traversal II Given a binary tree, return the bottom-up level order traversal ...
- Redis下载和安装
原文地址:https://redis.io/download Download Redis uses a standard practice for its versioning: major.min ...
- matplotlib热图
1.基础知识点回顾 1.plot(x, y, marker='D')表示绘制折线图,marker设置样式菱形. 2.scatter(x, y, marker='s', color='r')绘制散点图, ...