一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - log4j2 RollingRandomAccessFile配置過程

log4j2 RollingRandomAccessFile配置過程

2021-10-28 10:45yyding1988 Java教程

這篇文章主要介紹了log4j2 RollingRandomAccessFile配置過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

log4j2 RollingRandomAccessFile配置

一、需求背景

1. 日志按小時壓縮成zip文件。

2. 僅保存距離當前時間最近24小時的歷史壓縮文件。

3. 壓縮封存的zip文件,按照零點為參考點糾偏。

4. 將com.roadway.acceptor.base.DebugUtils類的日志輸出到指定文件,且不再輸出到其他文件。

二、log4j2 配置實現(xiàn)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO" monitorInterval="120">
    <properties
        <property name="MSG_LOG_HOME">/data/gpslog</property>
    </properties>
    <Appenders>
        <Console name="Console" target="SYSTEM_OUT">
            <PatternLayout pattern="%d [%t] %-5p [%c] - %m%n" />
        </Console>
        <RollingRandomAccessFile name="msgAppender" immediateFlush="true"
            fileName="${MSG_LOG_HOME}/msg.log"
            filePattern="${MSG_LOG_HOME}/backup/msg.%d{yyyyMMddHH}.zip">
            <Filters>
                <ThresholdFilter level="INFO" onMatch="ACCEPT" onMismatch="DENY"/>
            </Filters>
            <PatternLayout pattern="%m%n" />
            <Policies>
                <TimeBasedTriggeringPolicy interval="1" modulate="true"/>
            </Policies
            <DefaultRolloverStrategy max="24">
                <Delete basePath="${MSG_LOG_HOME}" maxDepth="2">
                  <IfFileName glob="*/msg.*.zip" />
                  <IfLastModified age="24H" />
                </Delete>
            </DefaultRolloverStrategy>
        </RollingRandomAccessFile>
    </Appenders>
    <Loggers>
        <AsyncLogger name="com.roadway.DebugUtils" additivity="FALSE" level="INFO">
            <appender-ref ref="msgAppender" />
        </AsyncLogger>
    </Loggers>
</Configuration>

三、配置說明

1. monitorInterval,博客配置的為120,單位為秒。即在服務運行過程中發(fā)生了log4j2配置文件的修改,log4j2能夠在monitorInterval時間范圍重新加載配置,無需重啟應用。

2. property配置文件全局屬性的聲明,使用方式為:${聲明的屬性名稱}。

${sys:catalina.home}為tomcat部署路徑,例如:/data/tomcat。

3. RollingRandomAccessFile基本屬性

  • name:Appender名稱
  • immediateFlush:log4j2接收到日志事件時,是否立即將日志刷到磁盤。默認為true。
  • fileName:日志存儲路徑
  • filePattern:歷史日志封存路徑。其中%d{yyyyMMddHH}表示了封存歷史日志的時間單位(目前單位為小時,yyyy表示年,MM表示月,dd表示天,HH表示小時,mm表示分鐘,ss表示秒,SS表示毫秒)。注意后綴,log4j2自動識別zip等后綴,表示歷史日志需要壓縮。

4. TimeBasedTriggeringPolicy

  • interval:表示歷史日志封存間隔時間,單位為filePattern設置的單位值
  • modulate:表示是否歷史日志生成時間糾偏,糾偏以零點為基準進行。比如:15:16生成了msg.2017041715.zip文件,那么糾偏后會在16:00生成msg.2017041716.zip

5. ThresholdFilter

  • level,表示最低接受的日志級別,博客配置的為INFO,即我們期望打印INFO級別以上的日志。
  • onMatch,表示當日志事件的日志級別與level一致時,應怎么做。一般為ACCEPT,表示接受。
  • onMismatch,表示日志事件的日志級別與level不一致時,應怎么做。一般為DENY,表示拒絕。也可以為NEUTRAL表示中立。

6. 保存24小時歷史日志,但不想用文件索引

?
1
2
3
4
5
6
<DefaultRolloverStrategy max="24">
    <Delete basePath="${MSG_LOG_HOME}" maxDepth="2">
        <IfFileName glob="*/msg.*.zip" />
        <IfLastModified age="24H" />
    </Delete>
</DefaultRolloverStrategy>

備注:

1. age的單位:D、H、M、S,分別表示天、小時、分鐘、秒

2. basePath表示日志存儲的基目錄,maxDepth=“1”表示當前目錄。因為我們封存的歷史日志在basePath里面的backup目錄,所以maxDepth設置為2。

7. RollingRandomAccessFile設置bufferSize不生效問題

  • a. log4j2配置如下:
?
1
2
3
4
5
6
<RollingRandomAccessFile name="msgAppender"
   immediateFlush="false"
   bufferSize="512"
   fileName="${MSG_LOG_HOME}/msg.log"
   filePattern="${MSG_LOG_HOME}/backup/msg.%d{yyyyMMddHH}.zip">
   ......
  • b. 使用異步Logger方式輸出日志
?
1
2
3
4
5
......
<AsyncLogger name="com.roadway.DebugUtils" additivity="FALSE" level="INFO">
    <appender-ref ref="msgAppender" />
</AsyncLogger>
......
  • c. 驗證

經過反復測試驗證,日志始終實時刷新到磁盤,這是為什么?查看log4j2文檔發(fā)現(xiàn):

Asynchronous loggers and appenders will automatically flush at the end of a batch of events, even if immediateFlush is set to false. This also guarantees the data is written to disk but is more efficient.

因此,如果期望使用 RollingRandomAccessFile異步的方式打印輸出日志,bufferSize是無法生效的且也沒有必要采用buffer的方式。

請參考log4j2官網地址

RandomAccessFile的常見用法

1.RandomAccessFile的簡介

1.1為什么要用到RandomAccessFile

我們平常創(chuàng)建流對象關聯(lián)文件,開始讀文件或者寫文件都是從頭開始的,不能從中間開始,如果是開多線程下載一個文件我們之前學過的FileWriter或者FileReader等等都無法完成,而當前介紹的RandomAccessFile他就可以解決這個問題,因為它可以指定位置讀,指定位置寫的一個類,通常開發(fā)過程中,多用于多線程下載一個大文件.

1.2.常用方法簡介

構造方法:RandomAccessFile raf = newRandomAccessFile(File file, String mode);

其中參數(shù) mode 的值可選 "r":可讀,"w" :可寫,"rw":可讀性;

成員方法:

seek(int index);可以將指針移動到某個位置開始讀寫;

setLength(long len);給寫入文件預留空間:

2.RandomAccessFile的特點和優(yōu)勢

這個對象有兩個優(yōu)點

1.既可以讀也可以寫

RandomAccessFile不屬于InputStream和OutputStream類系的它是一個完全獨立的類,所有方法(絕大多數(shù)都只屬于它自己)都是自己從頭開始規(guī)定的,這里面包含讀寫兩種操作

2.可以指定位置讀寫

RandomAccessFile能在文件里面前后移動,在文件里移動用的seek( ),所以它的行為與其它的I/O類有些根本性的不同??偠灾且粋€直接繼承Object的,獨立的類。只有RandomAccessFile才有seek搜尋方法,而這個方法也只適用于文件.

3.通過案例來熟悉RandomAccessFile的最常用的操作

首先創(chuàng)建一個DownLoadThread的類繼承Thread

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
public class DownLoadThread extends Thread {?
    private long start;
    private File src;
    private long total;
    private File desc;
?
    /**
     *
     * @param start
     *            開始下載的位置
     * @param src
     *            要下載的文件
     * @param desc
     *            要下載的目的地
     * @param total
     *            要下載的總量
     */
    public DownLoadThread(long start, File src, File desc, long total) {
        this.start = start;
        this.src = src;
        this.desc = desc;
        this.total = total;
    }
?
    @Override
    public void run() {
        try {
            // 創(chuàng)建輸入流關聯(lián)源,因為要指定位置讀和寫,所以我們需要用隨機訪問流
            RandomAccessFile src = new RandomAccessFile(this.src, "rw");
            RandomAccessFile desc = new RandomAccessFile(this.desc, "rw");
?
            // 源和目的都要從start開始
            src.seek(start);
            desc.seek(start);
            // 開始讀寫
            byte[] arr = new byte[1024];
            int len;
            long count = 0;
            while ((len = src.read(arr)) != -1) {
                //分三種情況
                if (len + count > total) {
                     //1.當讀取的時候操作自己該線程的下載總量的時候,需要改變len
                    len = (int) (total - count);
                    desc.write(arr, 0, len);
                    //證明該線程下載任務已經完畢,結束讀寫操作
                    break;
                } else if (len + count < total) {
                    //2.證明還沒有到下載總量,直接將內容寫入
                    desc.write(arr, 0, len);
                    //并且使計數(shù)器任務累加
                    count += arr.length;
                } else {
                    //3.證明改好到下載總量
                    desc.write(arr, 0, len);
                    //結束讀寫
                    break;
                }
            }
            src.close();
            desc.close();
?
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

然后定義主方法進行文件的測試

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class TestRandomAccess {?
    public static void main(String[] args) {
        //關聯(lián)源
        File src = new File("a.txt");
        //關聯(lián)目的
        File desc = new File("b.txt");
?
        //獲取源的總大小
        long length = src.length();
        // 開兩條線程,并分配下載任務
        new DownLoadThread(0, src, desc, length / 2).start();
        new DownLoadThread(length / 2 , src, desc, length - (length / 2)).start();
    }?
}

4.效果展示

a.txt的內容

log4j2 RollingRandomAccessFile配置過程

b.txt的內容

log4j2 RollingRandomAccessFile配置過程

5.總結

從以上分析可以看出RandomAccessFile最大兩個特點:

1.可以指定位置開始操作

2.既可以讀,也可以寫

所以,我們但凡遇到不是需要從文件中中間部分開始讀取的時候,可以使用RandomAccessFile這個類,比如:多線程下載是最常用的應該場景

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/yyding1988/article/details/84882627

延伸 · 閱讀

精彩推薦
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發(fā)現(xiàn)了對于集合操作轉換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關于Java8中S...

    阿杜7482021-02-04
  • Java教程Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進去或缺失數(shù)據(jù)的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java實現(xiàn)搶紅包功能

    Java實現(xiàn)搶紅包功能

    這篇文章主要為大家詳細介紹了Java實現(xiàn)搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關于小米推送Java代碼,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩(wěn)中求8032021-07-12
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經有好久沒有升過級了。升級完畢重啟之后,突然發(fā)現(xiàn)好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發(fā)項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml與Java對象的轉換詳解

    xml與Java對象的轉換詳解

    這篇文章主要介紹了xml與Java對象的轉換詳解的相關資料,需要的朋友可以參考下...

    Java教程網2942020-09-17
主站蜘蛛池模板: 亚洲成在人网站天堂一区二区 | 日韩在线视频一区二区三区 | 大胸美女被c| 欧美老人与小伙子性生交 | 波多野结衣久久国产精品 | 91麻豆精品国产91久久久 | 欧美破苞合集 magnet | free哆拍拍免费永久视频 | 国产亚洲精aa在线观看香蕉 | 我们日本在线观看免费动漫下载 | 天堂在线中文字幕 | 国产精品亚洲精品日韩已方 | 亚洲美女人黄网成人女 | 国产一区二区三区福利 | 男男18视频免费网站 | 国产一卡二卡3卡4卡更新 | 亚洲欧美国产自拍 | 91高清免费国产自产 | 成人在线一区二区 | 精品国产福利片在线观看 | 香蕉视频在线观看网址 | 情乱奶水欲| 免费特黄一区二区三区视频一 | 久久WWW免费人成一看片 | 午夜一个人在线观看完整版 | youzljzljzljzlj96| 免费永久视频 | 国产小视频在线免费观看 | 高清毛片aaaaaaaaa片 | 亚洲国产在线播放 | 国产日韩精品一区二区 | 国产人妖ts在线视频网 | 国产小视频在线 | 午夜国产在线观看 | 亚洲AV无码国产精品色午夜情 | 免费福利资源站在线视频 | 91频视| 国产成人精品一区二区阿娇陈冠希 | 日韩免费观看成第15集 | xxx久久| 视频精品一区二区三区 |