log4j-core2.17.1詳解

一、核心概念

log4j是一個靈活的、快速的、多種日誌輸出的Java日誌庫。log4j-core是log4j庫的核心模塊,它包含了Logger、Appender、Layout等核心概念和實現方式。Logger是log4j中最核心的概念之一,用於控制日誌輸出級別和日誌輸出的目的地。Appender用於指定日誌輸出的目的地,可以是控制台、文件、數據庫等等。Layout用於定義日誌消息的布局,例如可以格式化輸出時間、類名、方法名等等信息。

二、Logger

Logger是log4j中最核心的概念之一,它用於控制日誌輸出級別和日誌輸出的目的地。Logger是根據類名獲取的,可以通過如下方式獲取Logger實例:

private static final Logger logger = LogManager.getLogger(MyClass.class);

然後可以通過設置日誌輸出級別和輸出目的地來控制日誌輸出。例如,可以使用如下方式設置日誌輸出級別為DEBUG:

logger.setLevel(Level.DEBUG);

還可以設置輸出目的地。例如,可以使用如下方式設置輸出到控制台:

ConsoleAppender consoleAppender = new ConsoleAppender();
consoleAppender.setThreshold(Level.DEBUG);
consoleAppender.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n"));
logger.addAppender(consoleAppender);

此時,logger輸出的日誌將同時輸出到文件和控制台。如果需要只輸出到文件或者只輸出到控制台,可以按照需求選擇Appender並添加到logger中。

三、Appender

Appender用於指定日誌輸出的目的地,可以是控制台、文件、數據庫等等。log4j-core提供了多種Appender,可以根據需求選擇對應的Appender。例如,ConsoleAppender用於輸出到控制台,FileAppender用於輸出到文件,JDBCAppender用於輸出到數據庫。

我們已經演示了如何將日誌同時輸出到文件和控制台,這裡再演示如何將日誌輸出到文件。例如,可以使用如下方式設置輸出到文件:

FileAppender fileAppender = new FileAppender();
fileAppender.setFile("example.log");
fileAppender.setThreshold(Level.DEBUG);
fileAppender.setLayout(new PatternLayout("%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %m%n"));
logger.addAppender(fileAppender);

此時,logger輸出的日誌將同時輸出到文件和控制台。如果需要只輸出到文件或者只輸出到控制台,可以按照需求選擇Appender並添加到logger中。

四、Layout

Layout用於定義日誌消息的布局,例如可以格式化輸出時間、類名、方法名等等信息。log4j-core提供了多種Layout,可以根據需求選擇對應的Layout。例如,PatternLayout用於定義輸出格式為指定的格式字符串。

我們已經演示了如何在Appender中使用PatternLayout設置日誌消息的布局,這裡再演示一個更加簡單的方法,在Logger中直接設置輸出格式。例如,可以使用如下方式設置輸出格式為指定的格式字符串:

LoggerContext loggerContext = (LoggerContext) LogManager.getContext(false);
Configuration configuration = loggerContext.getConfiguration();
LoggerConfig loggerConfig = configuration.getLoggerConfig(LogManager.ROOT_LOGGER_NAME);
loggerConfig.removeAppenders();
loggerConfig.getAppenderRefs().forEach(appenderRef -> {
    String appenderName = appenderRef.getRef();
    Appender appender = configuration.getAppender(appenderName);
    appender.stop();
    loggerConfig.removeAppender(appenderName);
});
ConsoleAppender consoleAppender = ConsoleAppender.createDefaultAppender();
consoleAppender.start();
LoggerConfig rootLoggerConfig = loggerContext.getRootLogger();
rootLoggerConfig.addAppender(consoleAppender, Level.ALL, null);
rootLoggerConfig.setLevel(Level.ALL);
ConfigurationScheduler scheduler = loggerContext.getConfigurationScheduler();
scheduler.start();

此時,logger輸出的日誌將按照指定的格式字符串輸出,格式字符串可以包含如下佔位符:

%d:輸出時間,例如yyyy-MM-dd HH:mm:ss.SSS

%c:輸出Logger的名稱,例如com.example.MyClass

%t:輸出當前線程的名稱,例如main

%L:輸出當前日誌輸出語句在代碼中的行號,例如42

%m:輸出日誌消息,例如Hello, World!

五、性能優化

log4j-core具有很高的性能,但是在某些情況下可能會出現性能問題。例如,如果在多線程環境中使用log4j,可能會出現性能瓶頸。此時可以考慮使用異步Appender來解決性能問題。異步Appender會將日誌消息放入內存隊列中,然後交給單獨的線程異步地將日誌消息輸出到目的地,從而避免在主線程中阻塞。

可以使用如下方式創建異步Appender:

AsyncAppender asyncAppender = AsyncAppender.newBuilder()
    .setAppender(fileAppender)
    .setBufferSize(1024 * 1024)
    .build();
logger.addAppender(asyncAppender);

其中,setAppender用於指定原始的Appender,這裡選擇的是FileAppender;setBufferSize用於指定內存隊列的大小,單位為位元組,默認值為256KB。可以根據實際情況調整內存隊列的大小。

六、總結

log4j-core是一個靈活的、快速的、多種日誌輸出的Java日誌庫的核心模塊,本文從Logger、Appender、Layout、性能優化等多個方面進行了詳細的闡述,並演示了多種log4j-core的用法,希望對大家有所幫助。

原創文章,作者:TWRKO,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/330493.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
TWRKO的頭像TWRKO
上一篇 2025-01-16 15:46
下一篇 2025-01-16 15:46

相關推薦

  • Log4j日誌打印到Systemout.log

    Log4j是Apache的一個強大的日誌組件,可以幫助開發者更好地管理日誌。在Java應用程序中,很多開發者都會選擇使用Log4j來實現日誌輸出。本文將介紹如何使用Log4j將日誌…

    編程 2025-04-28
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁盤中。在執行sync之前,所有的文件系統更新將不會立即寫入磁盤,而是先緩存在內存…

    編程 2025-04-25
  • 神經網絡代碼詳解

    神經網絡作為一種人工智能技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網絡的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網絡模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性傳感器,能夠同時測量加速度和角速度。它由三個傳感器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分佈式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變量讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • C語言貪吃蛇詳解

    一、數據結構和算法 C語言貪吃蛇主要運用了以下數據結構和算法: 1. 鏈表 typedef struct body { int x; int y; struct body *nex…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25

發表回復

登錄後才能評論