कौंसल - क्वेरी नोड्स
इस अध्याय में, हम सीखेंगे कि निम्नलिखित क्रियाओं के साथ नोड्स की क्वेरी कैसे करें -
- खुदाई का उपयोग करना
- मॉनिटर कमांड का उपयोग करना
- वॉच कमांड का उपयोग करना
- बाहरी सेवाओं को पंजीकृत करके
आइए हम इनमें से प्रत्येक कार्य को विस्तार से समझते हैं।
डीग का उपयोग करना
कौंसुल में 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
हमें निम्न स्क्रीनशॉट में दिखाए अनुसार यूआई की जांच करनी चाहिए।