首頁 > 軟體

Spring Boot Actuator管理紀錄檔的實現

2022-07-04 22:02:49

為了解決以下兩個問題:

1、單JAR包應用檢視紀錄檔需要的時候如果需要遠端存取伺服器登入檢視紀錄檔,那樣相對比較麻煩

2、生產環境為了解決BUG需要臨時更換紀錄檔級別,總不能重啟服務來解決吧

所以使用了actuator 其中的部分來解決這兩個問題。

首先在POM檔案中引入actuator依賴:

  <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
            <version>${spring-boot.version}</version>
 </dependency>

組態檔中設定:

management.endpoints.web.base-path=/actuator
management.endpoints.web.exposure.include=logfile,loggers 
management.endpoint.health.show-details=always
logging.file.name=logs/EL-3KJ/EL-3KJ.log

 然後直接可以存取    http://localhost:8085/actuator

得到下列結果:

{"_links":{
        "self"{"href":"http://localhost:8085/actuator","templated":false},
        "logfile:         {"href":"http://localhost:8085/actuator/logfile","templated":false},"loggers":{"href":"http://localhost:8085/actuator/loggers","templated":false},"loggers-name":{"href":"http://localhost:8085/actuator/loggers/{name}","templated":true}}}

其中

  • logfile 是檢視紀錄檔檔案
  • loggers是檢視紀錄檔級別
  • loggers/{name}是更改紀錄檔級別

前端參考程式碼:

 <TabPane label="介面紀錄檔" name="name3">
                級別:
                <RadioGroup v-model="loglevel" type="button" size="small" @on- 
                      change="lvChange()">
                  <Radio label="ERROR"></Radio>
                  <Radio label="INFO"></Radio>
                  <Radio label="DEBUG"></Radio>
                </RadioGroup> <br/><br/>
                檔案:<a :href="logfileurl" rel="external nofollow"  target="_blank"  > 檢視</a>
 </TabPane>
 
 
 
 this.logfileurl = res.dataApi+"actuator/logfile";
 this.loglevelurl = res.dataApi+"actuator/loggers/root";
 
 
getLogLevel(){
      this.ajax_get({
        url: this.loglevelurl,
        params: {},
      }).then((res) => {
        this.loglevel=res.configuredLevel
      });
},
lvChange(){
      this.changeLogLevel(this.loglevel)
},
changeLogLevel(level){
      this.ajax_post({
        url: this.tenant.dataApi + "actuator/loggers/root",
        params: {'configuredLevel':level},
      }).then((res) => {
        this.spinShow = false;
        if (!res.code) {
          this.$Notice.success({
            title:'更改紀錄檔級別為'+level,
            desc:res.msg
          });
        } else {
          this.$Notice.error({
            title:'更改紀錄檔級別失敗',
            desc:res.msg
          });
        }
      });
 }

最終效果如下:

 到此這篇關於Spring Boot Actuator管理紀錄檔的實現的文章就介紹到這了,更多相關Spring Boot Actuator管理紀錄檔內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com