साल्टस्टैक - लॉगिंग

लॉगिंग का उपयोग रनिंग सॉफ़्टवेयर इवेंट को ट्रैक करने के लिए किया जाता है। एक घटना एक वर्णनात्मक संदेश द्वारा वर्णित है, जिसमें वैकल्पिक रूप से चर डेटा हो सकता है। नमक लॉगिंग दृष्टिकोण किसी भी मुद्दे को प्राप्त करने के लिए उपयोग किया जाता है, आप सामना कर सकते हैं। आप विशिष्ट लॉग स्तरों के साथ देख सकते हैं।

कॉन्फ़िगरेशन सेटिंग्स

आइए हम लॉगिंग के लिए विभिन्न कॉन्फ़िगरेशन सेटिंग्स को विस्तार से समझते हैं।

लॉग फ़ाइल

नमक लॉग रिकॉर्ड फ़ाइल के माध्यम से पारित किए जाते हैं, जिसमें पहचान के लिए स्थानीय पथ नाम या नेटवर्क स्थान होता है। इस फाइल को लॉग फाइल माना जाता है।

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 संतरी_हैंडलर कॉन्फ़िगरेशन कुंजी के तहत।