साल्टस्टैक - लॉगिंग
लॉगिंग का उपयोग रनिंग सॉफ़्टवेयर इवेंट को ट्रैक करने के लिए किया जाता है। एक घटना एक वर्णनात्मक संदेश द्वारा वर्णित है, जिसमें वैकल्पिक रूप से चर डेटा हो सकता है। नमक लॉगिंग दृष्टिकोण किसी भी मुद्दे को प्राप्त करने के लिए उपयोग किया जाता है, आप सामना कर सकते हैं। आप विशिष्ट लॉग स्तरों के साथ देख सकते हैं।
कॉन्फ़िगरेशन सेटिंग्स
आइए हम लॉगिंग के लिए विभिन्न कॉन्फ़िगरेशन सेटिंग्स को विस्तार से समझते हैं।
लॉग फ़ाइल
नमक लॉग रिकॉर्ड फ़ाइल के माध्यम से पारित किए जाते हैं, जिसमें पहचान के लिए स्थानीय पथ नाम या नेटवर्क स्थान होता है। इस फाइल को लॉग फाइल माना जाता है।
log_file: /var/log/salt/master
यहां, बाइनरी के मास्टर में निष्पादित फ़ाइल पर निर्भर करता है। इसी तरह, आप मिनियन में भी निष्पादित कर सकते हैं, जो नीचे दिखाया गया है।
log_file: /var/log/salt/minion
आप रिमोट एड्रेस का भी उपयोग कर सकते हैं। दूरस्थ पते का उपयोग करने के लिए वाक्यविन्यास है - <फ़ाइल | udp | tcp>: // <host | socketpath>: <port-if-आवश्यक> / <log-सुविधा>।
log_file: udp://loghost:port
यहाँ, लॉग-सुविधा Log_USER को डिफॉल्ट करता है।
छांटने का स्तर
लॉग स्तर एक क्रमबद्ध रूप से असाइन किए गए मान में दिए गए हैं। पायथन लाइब्रेरी ने डिफ़ॉल्ट रूप से लॉगिंग के अधिकांश स्तरों को परिभाषित किया है। इसके अतिरिक्त, नमक कुछ और स्तरों का उपयोग करता है। कुछ स्तरों के बारे में नीचे बताया गया है।
log_level: error; level value is 40 - यह त्रुटि पर लॉग स्टेटमेंट रिकॉर्ड इंगित करता है।
log_level: quiet; level value is 1000 - यह इंगित करता है कि इस स्तर पर कुछ भी लॉग नहीं किया जाना चाहिए।
log_level: info; level value is 20 - यह सामान्य लॉग जानकारी को इंगित करता है।
log_level: warn; level value is 30 - यह चेतावनी पर लॉग स्टेटमेंट रिकॉर्ड को इंगित करता है।
log_level: debug; level value is 10 - नमक कार्यान्वयन और नमक कोड दोनों को डीबग करने के लिए उपयोगी जानकारी।
log_level: trace; level value is 5 - अधिक विस्तृत कोड-डिबगिंग जानकारी।
LOG_LEVEL_LOGFILE
यह लॉग फ़ाइल में भेजने के लिए संदेशों के स्तर को परिभाषित करता है।
log_level_logfile: info
LOG_DATEFMT
यह लॉग डेट फॉर्मेट को परिभाषित करता है। डिफ़ॉल्ट रूप से, इसे% Y-% m-% d% H:% M:% S के रूप में दर्शाया गया है।
log_datefmt_logfile: '%Y-%m-%d %H:%M:%S'
LOG_FMT_CONSOLE
यह संदेश लॉग करने वाले कंसोल के प्रारूप को परिभाषित करता है। नमक एक प्रथा का उपयोग करता हैLogRecordकंसोल लॉग आउटपुट को रंगीन करने के लिए विशेषताएँ। यह निम्नलिखित सिंटैक्स का अनुसरण करता है -
'%(colorlevel)s' # log level name colorized by level
'%(colorname)s' # colorized module name
'%(colorprocess)s' # colorized process number
'%(colormsg)s' # colorized messages name
LOG_FMT_LOGFILE
यह लॉग फ़ाइल लॉगिंग संदेशों के प्रारूप को परिभाषित करता है। मूल वाक्य रचना इस प्रकार है -
%(asctime)s,%(msecs)03d [%(name)-17s][%(levelname)-8s] %(message)s
LOG_GRANULAR_LEVELS
इस स्तर का उपयोग लॉगिंग स्तरों को अधिक विशेष रूप से नियंत्रित करने के लिए किया जाता है।
log_granular_levels:
'salt': 'info'
'salt.modules': ‘trace'
यहाँ, 'सूचना' स्तर पर मुख्य नमक पुस्तकालय सेट करता है salt.modules ट्रेस स्तर पर लॉग इन करें।
बाहरी लॉगिंग हैंडलर
नमक लॉगिंग के लिए लॉगस्टैश और सेंटरी बाहरी लॉग हैंडलर का उपयोग करता है। आइये इस अध्याय में इसके बारे में विस्तार से समझते हैं।
LOGSTASH हैंडलर
लॉगस्टैश एक खुला स्रोत है; सर्वर-साइड सुरक्षित डाटा प्रोसेसिंग पाइपलाइन। आइए हम एक साधारण यूडीपी लॉगिंग हैंडलर इन नमक पर विचार करें जो लॉगस्टैश का उपयोग करता है।
साल्ट मास्टर फ़ाइल में निम्नलिखित परिवर्तन निर्दिष्ट करें -
logstash_udp_handler:
host: 127.0.0.1
port: 9999
version: 1
msg_type: logstash
फिर लॉगस्टैश कॉन्फ़िगरेशन फ़ाइल में परिवर्तन जोड़ें -
input {
udp {
port ⇒ 9999
codec ⇒ json
}
}
यहाँ, UDP - इनपुट है कि एक प्रारूप के रूप में की जरूरत है json_event, जो हम तार पर भेजते हैं।
SENTRY लॉगिंग हैंडलर
संतरी वास्तविक समय में उत्पादन की तैनाती और दुर्घटनाओं को ठीक करने और ठीक करने के लिए सूचना ट्रैक करने में त्रुटि है। मास्टर फ़ाइल में डिफ़ॉल्ट कॉन्फ़िगरेशन नीचे परिभाषित किया गया है।
sentry_handler:
dsn: https://pub-key:[email protected]/app-id
log_level: debug
यहां, संतरी हैंडलर के लिए डिफ़ॉल्ट लॉगिंग स्तर ERROR है, लेकिन हमने डिबग को परिभाषित किया है log_level संतरी_हैंडलर कॉन्फ़िगरेशन कुंजी के तहत।