亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

log4j如何根據(jù)變量動態(tài)生成文件名

 更新時間:2021年12月27日 11:37:37   作者:追風夏  
這篇文章主要介紹了log4j如何根據(jù)變量動態(tài)生成文件名方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

根據(jù)變量動態(tài)生成文件名

簡單的log4j設置

一般情況下,log4j配置文件簡單的設置為:

log4j.rootLogger=debug,stdout,R
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.File=test.log
log4j.appender.R.MaxFileSize=100KB
log4j.appender.R.DatePattern = '.'yyyy-MM-dd
log4j.appender.R.layout=ex.log4j.ExPatternLayout
log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %c %5p  - %m%n
log4j.appender.R.MaxBackupIndex=1

簡單實例

java代碼如下:

public class LogTest {
static Logger log = Logger.getLogger(LogTest.class);
public static void main(String[] args) throws IOException {
PropertyConfigurator.configure("log4j.properties");
log.debug("helo");
}
}

一般如上設置即可滿足簡單的log4j需求。

如果需要根據(jù)程序中的變量,將日志打到不同的文件中時,(如:根據(jù)某個ID,這樣對于大量日志時更加容易查找到想要的日志)

只需在java代碼中過去到所配置的FileAppender,然后serFile來修改文件名。

java代碼如下:

FileAppender appender = (FileAppender) log.getRootLogger().getAppender("R");
appender.setFile(filePath/fileName);
appender.activateOptions();

日志打印前,設置以上代碼,即可。

注意:加上 appender.activateOptions(); 可以使得后面打印的日志不會將之前的日志覆蓋。

log4j動態(tài)文件名

在項目中,對log的輸出有多種多樣的要求,下面具體分析一下動態(tài)log文件名輸出的。

一、按照用戶ID來生成log

這種情況,可以根據(jù)每個用戶ID來動態(tài)生成logger。

代碼如下:

import org.apache.log4j.FileAppender;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.RollingFileAppender;
public class LoggerUtil {
   
    public static Logger getLoggerByName(String name) {
        // 生成新的Logger
        // 如果已經(jīng)有了一個Logger實例返回現(xiàn)有的
        Logger logger = Logger.getLogger(name);
        // 清空Appender。特別是不想使用現(xiàn)存實例時一定要初期化
        logger.removeAllAppenders();
        // 設定Logger級別。
        logger.setLevel(Level.DEBUG);
        // 設定是否繼承父Logger。
        // 默認為true。繼承root輸出。
        // 設定false後將不輸出root。
        logger.setAdditivity(true);
        // 生成新的Appender
        FileAppender appender = new RollingFileAppender();
        PatternLayout layout = new PatternLayout();
        // log的輸出形式
        String conversionPattern = "[%d] %p %t %c - %m%n";
        layout.setConversionPattern(conversionPattern);
        appender.setLayout(layout);
        // log輸出路徑
        // 這里使用了環(huán)境變量[catalina.home],只有在tomcat環(huán)境下才可以取到
        String tomcatPath = java.lang.System.getProperty("catalina.home");
        appender.setFile(tomcatPath + "/logs/" + name + ".log");
        // log的文字碼
        appender.setEncoding("UTF-8");
        // true:在已存在log文件后面追加 false:新log覆蓋以前的log
        appender.setAppend(true);
        // 適用當前配置
        appender.activateOptions();
        // 將新的Appender加到Logger中
        logger.addAppender(appender);
        return logger;
    }
}

二、在batch程序中,通過一個設定來實現(xiàn)每個batch

文件名不同的設定。

log.xml定義

    <appender name="daily" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="file" value="/opt/tuhan.crm/batch/log/${tuhan.crm.log.name}.log" />
        <param name="threshold" value="debug"/>
        <param name="DatePattern" value="yyyyMMdd"/>
        <param name="append" value="true" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                value="%d{yyyy-MMM-dd HH:mm:ss,SSS}\t[%-5p]\t(%c:%L)\t%m%n"/>
        </layout>
    </appender>

log4j可以接受自定義環(huán)境變量,注意下面行【${tuhan.crm.log.name}】就是自定義環(huán)境變量

<param name="file" value="/opt/tuhan.crm/batch/log/${tuhan.crm.log.name}.log" />

那么環(huán)境變量如何設置呢,有2種方法

1.Java中設定(在使用配置文件之前, 要在程序中聲明這些變量):

System.setProperty("tuhan.crm.log.name", "batch001");

2.在JVM設定

java -Xmx512M -Dtuhan.crm.log.name=batch001 com.stu.TestBatch001

三、在batch程序中,通過多個設定來實現(xiàn)每個batch

文件名不同的設定。

動態(tài)的配置文件路徑: (log4j可以接受URL)

java.net.URL URL = consandpatt.class.getResource("/com/test/java/log/config/log4jConfig.properties");
PropertyConfigurator.configure(URL);

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • spring?boot集成redisson的最佳實踐示例

    spring?boot集成redisson的最佳實踐示例

    這篇文章主要為大家介紹了spring?boot集成redisson的最佳實踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-03-03
  • Java遍歷Properties所有元素的方法實例

    Java遍歷Properties所有元素的方法實例

    這篇文章主要介紹了Java如何遍歷Properties所有元素的方法,大家可以參考使用
    2013-11-11
  • java文件操作之Path,Paths,Files

    java文件操作之Path,Paths,Files

    Java7中文件IO發(fā)生了很大的變化,專門引入了很多新的類,下面給大家分享用Files作為一個操作類的實例,需要的朋友可以參考
    2017-04-04
  • java.lang.OutOfMemoryError 錯誤整理及解決辦法

    java.lang.OutOfMemoryError 錯誤整理及解決辦法

    這篇文章主要介紹了java.lang.OutOfMemoryError 錯誤整理及解決辦法的相關資料,需要的朋友可以參考下
    2016-10-10
  • Spring中的事務管理如何配置

    Spring中的事務管理如何配置

    這篇文章主要介紹了spring中的事務管理如何配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • Java對時間的簡單操作實例

    Java對時間的簡單操作實例

    這篇文章主要介紹了Java對時間的簡單操作,實例分析了針對java.util.Date的各類常見操作,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • AbstractProcessor擴展MapStruct自動生成實體映射工具類

    AbstractProcessor擴展MapStruct自動生成實體映射工具類

    這篇文章主要為大家介紹了AbstractProcessor擴展MapStruct自動生成實體映射工具類實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • 帶你快速搞定java多線程(5)

    帶你快速搞定java多線程(5)

    這篇文章主要介紹了java多線程編程實例,分享了幾則多線程的實例代碼,具有一定參考價值,加深多線程編程的理解還是很有幫助的,需要的朋友可以參考下
    2021-07-07
  • MybatisPlus中插入數(shù)據(jù)后獲取該對象主鍵值的實現(xiàn)

    MybatisPlus中插入數(shù)據(jù)后獲取該對象主鍵值的實現(xiàn)

    這篇文章主要介紹了MybatisPlus中插入數(shù)據(jù)后獲取該對象主鍵值,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • java實現(xiàn)十六進制字符unicode與中英文轉換示例

    java實現(xiàn)十六進制字符unicode與中英文轉換示例

    當需要對一個unicode十六進制字符串進行編碼時,首先做的應該是確認字符集編碼格式,在無法快速獲知的情況下,通過一下的str4all方法可以達到這一目的
    2014-02-02

最新評論