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

来源:https://www.cnblogs.com/lukelook/archive/2018/03/25/8646908.html
-Advertisement-
Play Games

一.java.util.logging.Logger簡介 java.util.logging.Logger不是什麼新鮮東西了,1.4就有了,可是因為log4j的存在,這個logger一直沉默著, 其實在一些測試性的代碼中,jdk自帶的logger比log4j更方便。 二.Logger的級別 比log ...


一.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輸出了一次

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。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 有一句段子流傳很久。 我精通各種語言的hello world !。 因為比如python3、c語言和javascript與學習網路安全關係非常大,所以說,對這幾門語言的關註比較多。 但是,在kali上學習的時候有一些東西非常值得註意,否則非常的耽誤時間,因為在這上面白白浪費了幾個小時的代價,所以說, ...
  • 在上章17.C++-string字元串類(詳解)學習了string類,發現可以通過[ ]重載操作符來訪問每個字元。 比如: 接下來,我們來自己寫個[ ]重載操作符,來模擬string類 運行列印: 函數對象 函數對象是指該對象具備函數的行為 函數對象,是通過()調用操作符聲明得到的,然後便能通過函數 ...
  • 學著寫了一下,終於搞定了,順便分享一下!taglib是tp框架自定義標簽功能,如果你用過cms,肯定見過類似: 或者: 這樣的操作,這對於開發工作是挺方便的,所以覺得有必要看下tp的taglib,教程如下:1 、在common(我是在common,你自己看,反正是用命名空間載入)里新建目錄tagli ...
  • 簡介 CDN,Content Distribute Network,可以直譯成內容分髮網絡,CDN解決的是如何將數據快速可靠從源站傳遞到用戶的問題。用戶獲取數據時,不需要直接從源站獲取,通過CDN對於數據的分發,用戶可以從一個較優的伺服器獲取數據,從而達到快速訪問,並減少源站負載壓力的目的。 動機 ...
  • 推導表達式其實就是簡化一些迴圈判斷操作等 生成一個數字1-10的列表,可以有多少種方法? 現在看下推導表達式 有些人,可能會說,直接range( 1, 11 )就好了,多此一舉,如果我們要篩選出奇數? 當然,range依然能夠做到: 那,如果要得到偶數,需要遍歷每一項,判斷 他等價於如下的推導表達式 ...
  • 自 JDK5 推出以來,註解已成為Java生態系統不可缺少的一部分。雖然開發者為Java框架(例如Spring的@Autowired)開發了無數的自定義註解,但編譯器認可的一些註解非常重要。 在本文中,我們將看到5個Java編譯器支持的註解,並瞭解其期望用途。順便,我們將探索其創建背後的基本原理,圍 ...
  • Java Web學習 一、搭建java web開發環境: (1)安裝jdk (2)安裝Tomcat伺服器(Apache的開源項目),安裝Tomcat並設置環境變數 (3)安裝EclipseEE(或者MyEclipse) 二、WEB-INF安全目錄介紹(只有伺服器可以訪問) (1)web.xml文件( ...
  • 這篇文章主要是為了溫習下平衡二叉樹,同時添加了樹型列印的介面,讓平衡二叉樹的添加和刪除更容易理解。 接下來的篇幅很長,需要有很多的耐心,做好了準備接下來往下看吧。 通俗的來說: 二叉樹就是節點度最大為2的樹,也就是最多包含兩個子樹,左子樹和右子樹,包含了空樹。 二叉排序樹(Binary Sort T ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...