欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JAVAlogback日志管理詳解

 更新時間:2021年09月01日 10:51:21   作者:軟件老王  
本篇文章主要介紹了在SpringBoot中使用Logback管理記錄日志,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

1、問題描述

關于java中的日志管理logback,去年寫過關于logback介紹的文章,這次項目中又優(yōu)化了下,記錄下,希望能幫到需要的朋友。

2、解決方案

這次其實是碰到了一個問題,一般的情況是,會單獨在linux上創(chuàng)建個用戶,線上和開發(fā)環(huán)境一樣,這樣腳本中假如有相對目錄的話,也能保持一致,但是這次因為線上環(huán)境創(chuàng)建其他用戶有問題,只能用root用戶操作,導致logback定義的目錄,開發(fā)和線上不一致,線上是root/***,開發(fā)環(huán)境沒有權限訪問該目錄(開發(fā)環(huán)境使用的普通用戶),所以logback的目錄,需要配置化,但是無法從application中獲取,換了個方式解決的,記錄下。

2.1 配置

<?xml version="1.0" encoding="UTF-8"?>

<configuration>
    <springProperty scope="context" name="LOG_HOME" source="path.log"/>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
    </appender>
    <appender name="FILE"  class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>${LOG_HOME}/laowangtest.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <MaxHistory>30</MaxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <MaxFileSize>1kb</MaxFileSize>
<!--                <MaxFileSize>5MB</MaxFileSize>- -->
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
    </appender>

    <!-- 日志輸出級別 -->
    <root level="INFO">
        <appender-ref ref="STDOUT" />
        <appender-ref ref="FILE" />
    </root>

</configuration>

簡要說明

1、目錄配置化

 <springProperty scope="context" name="LOG_HOME" source="path.log"/>

其中application.yml中配置是這樣的:

path:
  log: e:/laowang/test

實際項目中還有另外的配置文件:application-dev.yml、application-test.yml、application-prod.yml,path.log是配置在每個文件中,每個里面的值不一樣,而不是配置在公共配置application.yml中,這樣根據打包規(guī)則就能獲取不同的日志目錄了。

另外至于為什么無法通過 方 式 獲 取 值 , 網 上 或 者 官 方 給 的 答 案 是 , 在 容 器 中 , l o g b a c k 先 與 a p p l i c a t i o n . y m l 加 載 了 , 所 以 通 過 {}方式獲取值,網上或者官方給的答案是,在容器中,logback先與application.yml加載了,所以通過 方式獲取值,網上或者官方給的答案是,在容器中,logback先與application.yml加載了,所以通過{}方式就拿不到值了;同時保險起見,將logback.xml文件名稱更改為logback-***.xml,例如:logback-spring.xml。

2、簡單介紹下目前的配置

配置了兩個Appender,一個打印到控制臺,一個是到文件,以前把文件按照info、warn、errro,根據日志級別區(qū)分了打印文件,現(xiàn)在感覺沒必要,就打印一個里面去,還按照以前方式滾動,首先按天,其次按大小滾動日志

   <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>${LOG_HOME}/laowangtest.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
            <MaxHistory>30</MaxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <MaxFileSize>1kb</MaxFileSize>
<!--                <MaxFileSize>5MB</MaxFileSize>- -->
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>

其中幾個參數:

(1)FileNamePattern,文件目錄;

(2)MaxHistory:日志保留天數;

(3)MaxFileSize:多大開始滾動(新增)日志,記得是5MB,后面還有B不要漏掉了。

2.2 效果

為了展示效果,把大小給成1kb滾動,弄個測試方法進行驗證

(1)測試方法

@Api(value = "test")
@RestController
public class TestController {
    Logger logger = LoggerFactory.getLogger(TestController. class);

    @RequestMapping(value ="/logTest")
    @ResponseBody
    public  String logTest() {
        logger.info("老王是帥哥老王是帥哥老王是帥哥");
        return "老王是帥哥!";
    }
}

(2)執(zhí)行效果

瀏覽器:

生成文件:

文件內容:

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • redis 使用lettuce 啟動內存泄漏錯誤的解決方案

    redis 使用lettuce 啟動內存泄漏錯誤的解決方案

    這篇文章主要介紹了redis 使用lettuce 啟動內存泄漏錯誤的解決方案,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • java根據網絡地址保存圖片的方法

    java根據網絡地址保存圖片的方法

    這篇文章主要為大家詳細介紹了java根據網絡地址保存圖片的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Java基礎教程之final關鍵字淺析

    Java基礎教程之final關鍵字淺析

    這篇文章主要給大家介紹了關于Java基礎教程之final關鍵字的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-06-06
  • SpringBoot整合EasyCaptcha實現(xiàn)圖形驗證碼功能

    SpringBoot整合EasyCaptcha實現(xiàn)圖形驗證碼功能

    這篇文章主要介紹了SpringBoot整合EasyCaptcha實現(xiàn)圖形驗證碼功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-02-02
  • java鏈式創(chuàng)建json對象的實現(xiàn)

    java鏈式創(chuàng)建json對象的實現(xiàn)

    本文主要介紹了java中如何通過最簡單的方式實現(xiàn)鏈式創(chuàng)建json對象,解決創(chuàng)建json代碼臃腫的問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • java處理csv文件上傳示例詳解

    java處理csv文件上傳示例詳解

    這篇文章主要為大家詳細介紹了java處理csv文件上傳示例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Mybatis 動態(tài)表名+Map參數傳遞+批量操作詳解

    Mybatis 動態(tài)表名+Map參數傳遞+批量操作詳解

    這篇文章主要介紹了Mybatis 動態(tài)表名+Map參數傳遞+批量操作詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Java程序員必備的11大IntelliJ插件(附地址)

    Java程序員必備的11大IntelliJ插件(附地址)

    這篇文章主要介紹了Java程序員必備的11大IntelliJ插件(附地址),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Java中如何使用Redis GEO測算經緯度距離

    Java中如何使用Redis GEO測算經緯度距離

    GEO也是Redis中提供的一種數據類型,可以將其理解成ZSet有序集合類型,本文給大家介紹Java-使用Redis GEO測算經緯度距離,感興趣的朋友一起看看吧
    2023-11-11
  • java中的內部類內部接口用法說明

    java中的內部類內部接口用法說明

    這篇文章主要介紹了java中的內部類內部接口用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09

最新評論