5.1 फिल्टर की सूची
लकड़हारा आपको संदेश फ़िल्टरिंग को बहुत ही शांत तरीके से कॉन्फ़िगर करने की अनुमति देता है। ऐसा करने के लिए, उसके पास सभी प्रकार के मापदंडों के साथ कुछ दर्जन फ़िल्टर हैं। नीचे दी गई तालिका सबसे लोकप्रिय लोगों को दिखाती है।
फिल्टर | विवरण | |
---|---|---|
1 | बर्स्टफिल्टर | आपको दिए गए लॉगिंग स्तर के लिए प्रति सेकंड संदेशों की आवृत्ति को नियंत्रित करने की अनुमति देता है। |
2 | समग्र फ़िल्टर | आपको एकाधिक अनुक्रमिक फ़िल्टर सेट करने की अनुमति देता है। |
3 | डायनामिक थ्रेसहोल्ड फ़िल्टर | लॉग में कुछ जानकारी मिलने पर आपको विस्तृत लॉगिंग सक्षम करने की अनुमति देता है। |
4 | मैपफिल्टर | आपको कई पैरामीटर से फ़िल्टर के लिए एक जटिल तार्किक अभिव्यक्ति बनाने की अनुमति देता है। |
5 | मार्करफिल्टर | आपको संदेशों को टैग द्वारा फ़िल्टर करने की अनुमति देता है, इवेंट लॉगिंग के दौरान टैग को पहले जोड़ा जाना चाहिए। |
6 | रेगेक्सफिल्टर | आपको एक मुखौटा सेट करने की अनुमति देता है - एक नियमित अभिव्यक्ति। |
7 | संरचित डेटा फ़िल्टर | आपको उनमें कुछ डेटा की उपस्थिति से संदेशों को फ़िल्टर करने की अनुमति देता है। |
8 | थ्रेड कॉन्टेक्स्टमैपफ़िल्टर | आपको वर्तमान थ्रेड के संदर्भ से लिए गए डेटा के आधार पर फ़िल्टर प्रबंधित करने की अनुमति देता है। |
9 | दहलीज फ़िल्टर | लॉग संदेश स्तर के आधार पर लॉगिंग को नियंत्रित करता है। |
10 | समय फ़िल्टर | आपको विशिष्ट समय पर फ़िल्टर चालू और बंद करने की अनुमति देता है। |
नीचे हम उनमें से सिर्फ तीन के बारे में बात करेंगे। आप इन फ़िल्टर के बारे में उनकी आधिकारिक वेबसाइट पर अधिक जान सकते हैं ।
5.2 टाइमफिल्टर
फ़िल्टर TimeFilter
आपको एक निश्चित समय पर फ़िल्टर चालू और बंद करने की अनुमति देता है, इसके 5 पैरामीटर हैं:
1 | शुरू | प्रारूप में लॉगिंग प्रारंभ समयHH:mm:ss |
2 | अंत | प्रारूप में लॉगिंग समयHH:mm:ss |
3 | समय क्षेत्र | समय क्षेत्र सेट करता है। |
4 | onMatch | यदि फ़िल्टर की स्थिति सही है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
5 | on बेमेल | यदि फ़िल्टर की स्थिति गलत है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
आइए एक फ़िल्टर सेट करें जो सुबह 5 बजे लॉगिंग चालू करेगा और इसे हर दिन सुबह 5:30 बजे बंद कर देगा। पूर्ण फ़िल्टर कॉन्फ़िगरेशन वाला एक उदाहरण नीचे दिया गया है:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages="">
<Appenders>
<RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{MM-dd-yyyy}.log.gz">
<TimeFilter start="05:00:00" end="05:30:00" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout>
<pattern>%d %p %c{1.} [%t] %m%n</pattern>
</PatternLayout>
<TimeBasedTriggeringPolicy />
</RollingFile>
</Appenders>
<Loggers>
<Root level="error">
<AppenderRef ref="RollingFile"/>
</Root>
</Loggers>
</Configuration>
5.3 रेगेक्स फ़िल्टर
फ़िल्टर RegexFilter
आपको संदेशों को फ़िल्टर करने के लिए मास्क (नियमित अभिव्यक्ति) सेट करने की अनुमति देता है। इस फ़िल्टर के 4 पैरामीटर हैं:
1 | regex | रेगुलर एक्सप्रेशन निर्दिष्ट करता है - एक मास्क जिसका उपयोग संदेशों को फ़िल्टर करने के लिए किया जाता है।HH:mm:ss |
2 | useRawMsg | संदेश में स्वरूपित करने से पहले (सत्य) या स्वरूपण के बाद (गलत) मास्क लगाया जाता है |
3 | onMatch | यदि फ़िल्टर की स्थिति सही है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
4 | on बेमेल | यदि फ़िल्टर की स्थिति गलत है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
चलिए एक फ़िल्टर सेट करते हैं जो केवल codegym शब्द वाले संदेशों को अनुमति देगा। पूर्ण फ़िल्टर कॉन्फ़िगरेशन वाला एक उदाहरण नीचे दिया गया है:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages="">
<Appenders>
<RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{MM-dd-yyyy}.log.gz">
<RegexFilter regex=".* codegym .*" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout>
<pattern>%d %p %c{1.} [%t] %m%n</pattern>
</PatternLayout>
<TimeBasedTriggeringPolicy />
</RollingFile>
</Appenders>
<Loggers>
<Root level="error">
<AppenderRef ref="RollingFile"/>
</Root>
</Loggers>
</Configuration>
5.4 थ्रेशोल्ड फ़िल्टर
थ्रेशोल्डफ़िल्टर फ़िल्टर आपको संदेश स्तर द्वारा फ़िल्टरिंग को कॉन्फ़िगर करने की अनुमति देता है। इसके केवल 3 पैरामीटर हैं:
1 | स्तर | संदेश लॉगिंग स्तर का नाम सेट करता है: ERROR , DEBUG , ... |
2 | onMatch | यदि फ़िल्टर की स्थिति सही है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
3 | on बेमेल | यदि फ़िल्टर की स्थिति गलत है तो कैसे लॉग इन करें । शायद ACCEPT , DENY या NEUTRAL । डिफ़ॉल्ट NEUTRAL । |
आइए एक फ़िल्टर सेट करें जो केवल स्तर के संदेशों को अनुमति देगा DEBUG
। पूर्ण फ़िल्टर कॉन्फ़िगरेशन वाला एक उदाहरण नीचे दिया गया है:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="warn" name="MyApp" packages="">
<Appenders>
<RollingFile name="RollingFile" fileName="logs/app.log" filePattern="logs/app-%d{MM-dd-yyyy}.log.gz">
<ThresholdFilter level="DEBUG" onMatch="ACCEPT" onMismatch="DENY"/>
<PatternLayout>
<pattern>%d %p %c{1.} [%t] %m%n</pattern>
</PatternLayout>
<TimeBasedTriggeringPolicy />
</RollingFile>
</Appenders>
<Loggers>
<Root level="error">
<AppenderRef ref="RollingFile"/>
</Root>
</Loggers>
</Configuration>
GO TO FULL VERSION