कौंसल - क्वेरी नोड्स

इस अध्याय में, हम सीखेंगे कि निम्नलिखित क्रियाओं के साथ नोड्स की क्वेरी कैसे करें -

  • खुदाई का उपयोग करना
  • मॉनिटर कमांड का उपयोग करना
  • वॉच कमांड का उपयोग करना
  • बाहरी सेवाओं को पंजीकृत करके

आइए हम इनमें से प्रत्येक कार्य को विस्तार से समझते हैं।

डीग का उपयोग करना

कौंसुल में DNS प्रश्नों के लिए 127.0.0.1:8600 पर कॉन्सल सुनता है। जिस तरह से यह निर्धारित करता है कि एक सेवा प्रदान करने के लिए कौन से नोड उपलब्ध हैं वे चेक का उपयोग कर रहे हैं जो या तो हो सकते हैं -

  • एक स्क्रिप्ट जिसे निष्पादित किया जाता है और यह एक रिटर्न देता है nagios compliant code

  • एक HTTP चेक जो एक HTTP प्रतिक्रिया कोड देता है।

  • एक TCP जाँच जो कि जाँच रही है कि क्या कोई पोर्ट खुला है।

कोशिश करने के लिए सामान्य आदेश dig है -

$ dig @127.0.0.1 -p <port> <service-name>.consul

अब, आइए हम एक नमूना देखें dig कमांड -

$ dig @127.0.0.1 -p 8600 web.service.consul

आउटपुट निम्न स्क्रीनशॉट में दिखाया जाएगा।

मॉनिटर कमांड का उपयोग करना

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

आइए हम निम्नलिखित कमांड को आजमाते हैं -

$ consul monitor

आउटपुट निम्न स्क्रीनशॉट में दिखाया जाएगा।

आप उप-कमांड जैसे -log-level और -rpc-address का उपयोग करके मॉनिटर कमांड भी सेट कर सकते हैं। डिफ़ॉल्ट रूप से, RPC का पता 127.0.0.1:8400 है। अधिक जानकारी के लिए, यहां क्लिक करें ।

वॉच कमांड का उपयोग करना

यह कमांड हमें नोड्स, सेवा सदस्यों, प्रमुख मूल्य, आदि की सूची में बदलाव के लिए देखने के लिए एक तंत्र प्रदान करता है। यह एक प्रक्रिया को देखने के नवीनतम मूल्यों के साथ भी आमंत्रित करता है। यदि कोई प्रक्रिया निर्दिष्ट नहीं है, तो वर्तमान मान संसाधित किए जाते हैंSTDOUT, जो कंसुल में डेटा का निरीक्षण करने का एक उपयोगी तरीका हो सकता है। निम्नलिखित स्क्रीनशॉट में दिखाए गए अनुसार कॉन्सल वॉच कमांड मदद के विभिन्न विकल्प हैं -

हमें एक डेमो के साथ बाहर की कोशिश करते हैं -type = service जैसा कि निम्नलिखित कमांड में दिखाया गया है।

$ consul watch -type = service -service = consul

इस विषय पर अधिक जानकारी के लिए, आप यहाँ क्लिक कर सकते हैं ।

बाहरी सेवाओं को पंजीकृत करके

एक बार पंजीकृत होने के बाद, डीएनएस इंटरफ़ेस सेवा के लिए उपयुक्त 'ए रिकॉर्ड्स' या CNAME रिकॉर्ड्स वापस करने में सक्षम होगा। आइए हम एक बाहरी सेवा को पंजीकृत करें, जैसे कि अमेज़ॅन निम्न कोड ब्लॉक और स्क्रीनशॉट में भी दिखाया गया है।

$ sudo curl -X PUT -d '{"Datacenter": "dc1", "Node": "amazon",
"Address": "www.amazon.com",
"Service": {"Service": "shop", "Port": 80}}'
http://127.0.0.1:8500/v1/catalog/register

उपरोक्त आदेश एक सेवा को दुकान के रूप में निर्दिष्ट करता है। इस नोड को पोर्ट 80 पर www.amazon.com पर उपलब्ध अपने यूआरएल के साथ अमेजन कहा जाता है । हमें यह सुनिश्चित करने के लिए कि हमने इस सेवा को सही ढंग से स्थापित किया है, कृपया कॉन्सल पर आउटपुट की जांच करें। इसके लिए कृपया लोकलहोस्ट: 8500 पर ब्राउज़र विंडो खोलें।

सेवा को हटाने के लिए, हम बस निम्नलिखित कमांड का उपयोग कर सकते हैं।

$ curl -X PUT -d '{"Datacenter": "dc1", "Node": "amazon"}'
http://127.0.0.1:8500/v1/catalog/deregister

हमें निम्न स्क्रीनशॉट में दिखाए अनुसार यूआई की जांच करनी चाहिए।