跳到主要內容

Spring boot v1.5 (二) logging

本篇主要介紹Logging的機制,Spring boot預設為logback framework,在開始之前先給大家熱身一下,每次執行Spring boot程式在Console上都會看到Spring的Banner如下


這Banner可以自訂喔,可以在google輸入ascii generator關鍵字,就可以找到很多產生這Banner文件,我使用的是這個,然後在/src/main/resources目錄中增加一個banner.txt檔案,然後把產生出來的Code複製到banner.txt的檔案上,也可以透過簡單的設定加上一些顏色
banner.txt
${AnsiColor.BRIGHT_BLUE}


 _        _______          _________ _______  _______ 
( \      (  ___  )|\     /|\__   __/(  ____ \/ ___   )
| (      | (   ) || )   ( |   ) (   | (    \/\/   )  |
| |      | |   | || |   | |   | |   | (_____     /   )
| |      | |   | || |   | |   | |   (_____  )   /   / 
| |      | |   | || |   | |   | |         ) |  /   /  
| (____/\| (___) || (___) |___) (___/\____) | /   (_/\
(_______/(_______)(_______)\_______/\_______)(_______/
                                                      
${AnsiColor.BRIGHT_GREEN}
Application Version: ${application.version}${application.formatted-version}
Spring Boot Version: ${spring-boot.version}${spring-boot.formatted-version}

有點跑掉不過執行結果如下:

這個banner.txt後續也會有一些實質的幫助喔。

Logging在程式開發中是一個基本、必要且非常重要的一項工作,先跟大家說明之後相關範例說明都有 log 可以查看相當方便,也可以習慣這樣的方式,不要甚麼都是System.out,在一個專案或是系統建置成功與否,logging機制相當重要,然後上線後的維運、遇到問題更是仰賴的根本,只要能知道原因就能解決,想要知道原因就一定要很清楚logging的處理方式。




學習目的:使用logback進行log。
學習時數:1.5 hr
教學影片:




pom.xml 說明(logback為預設值,不用額外設定,同Spring boot v1.5(一))
spring-boot-starter-web:配置 Web Project所需的函式庫
spring-boot-starter-test:配置 unit or mock test 所需的函式庫
spring-boot-starter-actuator:配置監控spring boot所需的函式庫,後續spring cloud會使用到,所以一開就導入

application.properties說明
#應用程式名稱
spring.application.name=Louisz Spring boot

#程式啟動 listener port or server.port = 0 自動
server.port = 8090

#選擇需要紀錄的package
logging.level.org.springframework.web=DEBUG
logging.level.louisz.springboot.example2=DEBUG

#將log記錄到指定的檔案中
logging.file=louisz.log

#顯示可以有色彩的屬性
spring.output.ansi.enabled= always

#建議使用logback設定檔案
logging.config=src/main/resources/logback-spring.xml
在 /src/main/resources/ 下增加 logback-spring.xml設定檔,簡易內容如下:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 使用預設值得base.xml -->
    <include resource="org/springframework/boot/logging/logback/base.xml"/>
    <!-- 選擇要記錄的package,並設定只要大於等於debug等級,就記錄下來 -->
    <logger name="org.springframework.web" level="DEBUG"/>
</configuration>
run example2
測試以下幾個網址,是否有log下來相關資訊
http://localhost:8090/log_debug
http://localhost:8090/log_info

進階版的 logback 設定

<!-- <configuration>
    使用logback的基本設定
    <include resource="org/springframework/boot/logging/logback/base.xml"/>
    指定特定目錄進行log,等級設為WARN,分別記錄在Console及檔案 
    <logger name="louisz.springboot.example1" level="WARN" additivity="false">
        <appender-ref ref="CONSOLE"/>
        <appender-ref ref="FILE"/>
    </logger>
    指定特定目錄進行log,等級設為DEBUG,分別記錄在Console及檔案 
    <logger name="louisz.springboot.example2" level="DEBUG" additivity="true">
        <appender-ref ref="CONSOLE"/>
        <appender-ref ref="FILE"/>
    </logger>
 </configuration> -->
 <!-- 全部進行Debug level紀錄,並且每30秒監控設定檔是否有異動 -->
<configuration debug="true" scan="true" scanPeriod="30 seconds">
     <!-- 記錄檔存放路徑 -->
    <property name="LOG_PATH" value="logs" />
    <!-- 歷史記錄檔存放路徑 -->
    <property name="LOG_ARCHIVE" value="${LOG_PATH}/archive" />
    <!-- 檔名規則 -->
    <timestamp key="timestamp-by-second" datePattern="yyyyMMdd'T'HHmmss"/>
    <appender name="Console-Appender" class="ch.qos.logback.core.ConsoleAppender">
        <layout>
            <!-- 紀錄存放格式 -->
            <pattern>%d %-5level [%thread] %logger{0} : %msg%n</pattern>
        </layout>
    </appender>
    <!-- 歷史記錄檔搬移規則及存放路徑 -->
    <appender name="File-Appender" class="ch.qos.logback.core.FileAppender">
        <file>${LOG_PATH}/logfile-${timestamp-by-second}.log</file>
        <encoder>
            <pattern>%d %-5level [%thread] %logger{0} : %msg%n</pattern>
            <!-- 套用格式規則置頂 -->
            <outputPatternAsHeader>true</outputPatternAsHeader>
        </encoder>
    </appender>
    <!-- 記錄檔異動規則 -->
    <appender name="RollingFile-Appender" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_PATH}/rollingfile.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_ARCHIVE}/rollingfile.log%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>30</maxHistory>
            <totalSizeCap>1KB</totalSizeCap>
        </rollingPolicy>
        <encoder>
            <pattern>%d %-5level [%thread] %logger{0} : %msg%n</pattern>
        </encoder>
    </appender>
    <!-- 非同步方式進行紀錄 -->
    <appender name="Async-Appender" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 套用至RollingFile-Appender -->
        <appender-ref ref="RollingFile-Appender" />
    </appender>
  <!-- 紀錄套用package、level等 -->
    <logger name="louisz.springboot.example2"  level="debug" additivity="false">
        <appender-ref ref="Console-Appender" />
        <appender-ref ref="File-Appender" />
        <appender-ref ref="Async-Appender" />
    </logger>
    <root>
        <appender-ref ref="Console-Appender" />
    </root>
</configuration>


程式碼說明
  • Example2.java
package louisz.springboot.example2;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * Louisz Spring boot introduce ex.2
 *
 */

@SpringBootApplication
public class Example2 {
 /**
  * 程式執行起點
  * 
  * @param args
  */
 public static void main(String[] args) {
  SpringApplication.run(Example2.class, args);

 }

}
  • Ex2Controller.java
package louisz.springboot.example2;

//採用的是slf4j外框
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class Ex2Controller {
 //請注意不要用static,才能使用this.getClass
  private final Logger logger = LoggerFactory.getLogger(this.getClass()); 
 
  //log level 設定為debug
 @RequestMapping("/log_debug")
    public String debug() {
  logger.debug("This is debug msg.");  
        return "debug level";
    } 
  //log level 設定為info
 @RequestMapping("/log_info")
    public String info() {
  logger.info("This is info msg.");  
        return "info level";
    } 
  //log level 設定為error
 @RequestMapping("/log_error")
    public String error() {
  logger.debug("This is error msg.");  
        return "error level";
    } 
 
}

Github code(louisz.springboot.example2)

參考連結:
https://springframework.guru/using-logback-spring-boot/
https://springframework.guru/logback-configuration-using-xml/
http://blog.didispace.com/spring-boot-banner/

留言

這個網誌中的熱門文章

使用Apache Http Server進行Proxy和LoadB alance

環境概述 OS:Linux Apache Http Server:2.2.21 安裝可以使用rpm或是抓source下來compile,建議前者 rpm –ivh apache-http-xxx.rpm 這裡請注意一下安裝的版本 http.conf 參數設定 Proxy < VirtualHost *:80>      ProxyPass targetPath fromPath | fromUrl < VirtualHost/>  範例如下 < VirtualHost *:80>      ProxyPass /app http://DomainName或IP:8888/app      ProxyPassReverse /app http://DomainName或IP:8888/app < VirtualHost/> 上述的參數設定為,將某主機的http通訊協定下的Web application(app),對應到本台Web Server的app下。這樣的Proxy架構的設定對企業內的Web應用程式相當有用處,若是遇到Web Application Server掛點只需要修改Proxy對應,不需要動到dns等等,是個滿便宜的Proxy架構設定喔。﹝不過要注意Web Application要注意redirectc和forward等的撰寫,盡量不要有絕對IP的出現﹞

IBM MQ Server To Server的簡易設定

IBM MQ 的STS建置方式,IBM Red Book已經說明的滿完整的,這裡稍微整理一下,步驟如下 在 MQ-A Server MQ QMGR(MQA) 上需要建立的物件定義如下: • 遠端佇列定義 PAYROLL.QUERY • 傳輸佇列定義 MQB(預設 = 遠端佇列管理程式名稱) • 程序定義 MQA.TO.MQB.PROCESS(對於 WebSphere MQ for AIX、HP-UX、Solaris 與 Windows,及 MQSeries for Compaq Tru64 UNIX 與 OS/2 Warp,並非必要) • 傳送端通道定義 MQA.TO.MQB • 接收端通道定義 MQB.TO.MQA • 本端佇列定義 MQ2 以下是必須建立在 MQ-B Server MQ QMGR(MQB) 中的物件定義: • 遠端佇列定義 PAYROLL.RESPONE • 傳輸佇列定義 MQA(預設值=遠端佇列管理程式名稱) • 程序定義 MQB.TO.MQA.PROCESS(對於 WebSphere MQ for AIX、HP-UX、Solaris 與 Windows,及 MQSeries for Compaq Tru64 UNIX 與 OS/2 Warp,並非必要) • 傳送端通道定義 MQB.TO.MQA • 接收端通道定義 MQA.TO.MQB • 本端佇列定義 MQ4 1.先啟動MQ-A Server上的QMGR(MQA),並使用Runmqsc進入。 2.在佇列管理程式 MQA 上執行下列指令。 遠端佇列定義 DEFINE QREMOTE(PAYROLL.QUERY) DESCR('MQA 的遠端佇列') REPLACE + PUT(ENABLED) XMITQ(MQB) RNAME(MQ4) RQMNAME(MQB) 註: 遠端佇列定義並非實體的佇列,但卻是引導訊息至傳輸佇列 (MQB) 的一種方式,以便能將訊息送至佇列管理程式 MQB。 傳輸佇列定義 DEFINE QLOCAL(MQB) DESCR('對 MQB 的傳輸佇列') REPLACE + USAGE(XMITQ) PUT(ENABLED) GET(ENABLED) TRIGGER TRIGTYPE(FIRST) + INITQ(SYSTEM.CHANN

IReport字型下拉選單中文亂碼

這個問題其實也不是很大啦,不過當你有很多的中文字型檔的時候可能就不知道要選哪一個,啟動IReport後,開啟報表後會發現左邊下拉選單中,最下面的字型清單中有出現方框,顯示不出該字型的名稱,這幾個字型應該是判斷新細明體,標楷體及細明體,如下圖 下載IReport的Source Code來檢查一下,it.businesslogic.ireport.gui.MainFrame發現這個JComboBox有特別設定Arial字型,當然只要是中文的都顯示不出來ㄚ,所以點掉這一行後重新編譯,嘿嘿就可以了。 jComboBoxFont.setFont(new java.awt.Font("Arial", 0, 11)); 我目前使用的版本為 IReport-3.0.0-src