स्प्रिंग बूट - लॉगिंग
स्प्रिंग बूट सभी आंतरिक लॉगिंग के लिए अपाचे कॉमन्स लॉगिंग का उपयोग करता है। स्प्रिंग बूट का डिफ़ॉल्ट कॉन्फ़िगरेशन जावा यूटिल लॉगिंग, लॉग 4 जे 2 और लॉगबैक के उपयोग के लिए एक समर्थन प्रदान करता है। इनका उपयोग करके, हम कंसोल लॉगिंग के साथ-साथ फाइल लॉगिंग को भी कॉन्फ़िगर कर सकते हैं।
यदि आप स्प्रिंग बूट स्टार्टर्स का उपयोग कर रहे हैं, तो लॉगबैक लॉगिंग के लिए एक अच्छा समर्थन प्रदान करेगा। इसके अलावा, लॉगबैक कॉमन लॉगिंग, यूटिल लॉगिंग, लॉग 4 जे और एसएलएफ 4 जे के लिए अच्छे समर्थन का उपयोग भी प्रदान करता है।
लॉग फॉर्मेट
डिफ़ॉल्ट स्प्रिंग बूट लॉग प्रारूप नीचे दिए गए स्क्रीनशॉट में दिखाया गया है।
जो आपको निम्नलिखित जानकारी देता है -
Date तथा Time जो लॉग की तारीख और समय देता है
Log level जानकारी, त्रुटि या चेतावनी दिखाता है
Process ID
--- जो एक विभाजक है
Thread name वर्ग कोष्ठक के भीतर संलग्न है []
Logger Name वह स्रोत वर्ग नाम दिखाता है
लॉग संदेश
कंसोल लॉग आउटपुट
डिफ़ॉल्ट लॉग संदेश कंसोल विंडो पर प्रिंट होगा। डिफ़ॉल्ट रूप से, "INFO", "ERROR" और "WARN" लॉग संदेश लॉग फ़ाइल में प्रिंट होंगे।
यदि आपको डिबग स्तर लॉग को सक्षम करना है, तो नीचे दिखाए गए कमांड का उपयोग करके अपना एप्लिकेशन शुरू करने पर डीबग ध्वज जोड़ें -
java –jar demo.jar --debug
आप अपने आवेदन में डिबग मोड को भी जोड़ सकते हैं।
debug = true
फ़ाइल लॉग आउटपुट
डिफ़ॉल्ट रूप से, सभी लॉग कंसोल विंडो पर प्रिंट होंगे और फाइलों में नहीं। यदि आप किसी फ़ाइल में लॉग प्रिंट करना चाहते हैं, तो आपको संपत्ति सेट करने की आवश्यकता हैlogging.file या logging.path Application.properties फ़ाइल में।
आप नीचे दिखाए गए गुण का उपयोग करके लॉग फ़ाइल पथ निर्दिष्ट कर सकते हैं। ध्यान दें कि लॉग फ़ाइल का नाम spring.log है।
logging.path = /var/tmp/
नीचे दी गई संपत्ति का उपयोग करके आप स्वयं लॉग फ़ाइल नाम निर्दिष्ट कर सकते हैं -
logging.file = /var/tmp/mylog.log
Note - 10 एमबी साइज तक पहुंचने के बाद फाइलें अपने आप रोटेट हो जाएंगी।
लॉग स्तर
स्प्रिंग बूट सभी लकड़हारा स्तरों का समर्थन करता है जैसे "TRACE", "DEBUG", "INFO", "WARN", "ERROR", "FATAL", "OFF"। आप रूट लकड़हारे को अनुप्रयोग में परिभाषित कर सकते हैं।
logging.level.root = WARN
Note- लॉगबैक "FATAL" स्तर लॉग का समर्थन नहीं करता है। यह "त्रुटि" स्तर लॉग करने के लिए मैप किया गया है।
लॉगबैक कॉन्फ़िगर करें
Logback स्प्रिंग बूट लॉग कॉन्फ़िगरेशन को संभालने के लिए XML आधारित कॉन्फ़िगरेशन का समर्थन करता है। लॉगिंग कॉन्फ़िगरेशन विवरण कॉन्फ़िगर किए गए हैंlogback.xmlफ़ाइल। लॉगबैक। Xml फ़ाइल को क्लासपाथ के नीचे रखा जाना चाहिए।
आप नीचे दिए गए कोड का उपयोग करके Logback.xml फ़ाइल में ROOT स्तर लॉग को कॉन्फ़िगर कर सकते हैं -
<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
<root level = "INFO">
</root>
</configuration>
आप नीचे दिए गए Logback.xml फ़ाइल में कंसोल ऐपेंडर को कॉन्फ़िगर कर सकते हैं।
<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
<appender name = "STDOUT" class = "ch.qos.logback.core.ConsoleAppender"></appender>
<root level = "INFO">
<appender-ref ref = "STDOUT"/>
</root>
</configuration>
आप नीचे दिए गए कोड का उपयोग करके लॉगबैक.एक्सएमएल फ़ाइल में फ़ाइल ऐपेंडर को कॉन्फ़िगर कर सकते हैं। ध्यान दें कि आपको लॉग फ़ाइल पथ को निर्दिष्ट करने की आवश्यकता है फ़ाइल के अंदरूनी सूत्र।
<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
<appender name = "FILE" class = "ch.qos.logback.core.FileAppender">
<File>/var/tmp/mylog.log</File>
</appender>
<root level = "INFO">
<appender-ref ref = "FILE"/>
</root>
</configuration>
आप लॉग पैटर्न को परिभाषित कर सकते हैं logback.xmlनीचे दिए गए कोड का उपयोग करके फ़ाइल। आप नीचे दिए गए कोड का उपयोग करके कंसोल या फ़ाइल लॉग ऐपेंडर के अंदर समर्थित लॉग पैटर्न के सेट को भी परिभाषित कर सकते हैं -
<pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>
पूर्ण logback.xml फ़ाइल के लिए कोड नीचे दिया गया है। आपको इसे क्लास पाथ में रखना होगा।
<?xml version = "1.0" encoding = "UTF-8"?>
<configuration>
<appender name = "STDOUT" class = "ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>
</encoder>
</appender>
<appender name = "FILE" class = "ch.qos.logback.core.FileAppender">
<File>/var/tmp/mylog.log</File>
<encoder>
<pattern>[%d{yyyy-MM-dd'T'HH:mm:ss.sss'Z'}] [%C] [%t] [%L] [%-5p] %m%n</pattern>
</encoder>
</appender>
<root level = "INFO">
<appender-ref ref = "FILE"/>
<appender-ref ref = "STDOUT"/>
</root>
</configuration>
नीचे दिया गया कोड स्प्रिंग बूट मुख्य वर्ग फ़ाइल में slf4j लकड़हारा जोड़ने का तरीका दिखाता है।
package com.tutorialspoint.demo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class DemoApplication {
private static final Logger logger = LoggerFactory.getLogger(DemoApplication.class);
public static void main(String[] args) {
logger.info("this is a info message");
logger.warn("this is a warn message");
logger.error("this is a error message");
SpringApplication.run(DemoApplication.class, args);
}
}
कंसोल विंडो में आप जो आउटपुट देख सकते हैं वह यहां दिखाया गया है -
लॉग फ़ाइल में आप जो आउटपुट देख सकते हैं वह यहाँ दिखाया गया है -