कौंसल - माइक्रोसर्विसेज के साथ काम करना

इस अध्याय में, हम यह समझेंगे कि माइक्रोसर्विस कंसूल के साथ कैसे काम करते हैं। हम यह भी सीखेंगे कि निम्नलिखित घटक कांसुल को कैसे प्रभावित करते हैं।

  • कर्ता का उपयोग करना
  • सर्विस डिस्कवरी के लिए बिल्डिंग रजिस्ट्रार
  • Rkt और घुमंतू का उपयोग करना

आइए अब हम इनमें से प्रत्येक के बारे में विस्तार से चर्चा करें।

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

शुरू करने से पहले, please do not use this setup in productionजैसा कि इसका उपयोग केवल डेमो उद्देश्यों के लिए किया जाता है। डॉकर एक कंटेनर आधारित सेवा है जिसका उपयोग करके हम आसानी से अपने अनुप्रयोगों को तैनात कर सकते हैं। कॉन्सल का उपयोग करने के लिए, हम निम्नलिखित लिंक पर छवि का उपयोग करने जा रहे हैं –0

https://hub.docker.com/r/progrium/consul/।

यह माना जा रहा है कि आपके सिस्टम में डॉकर स्थापित है और ठीक से कॉन्फ़िगर किया गया है। आइए हम निम्नलिखित कमांड को चलाकर डॉकटर हब से छवि को नीचे खींचने की कोशिश करते हैं -

$ docker pull progrium/consul

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

हम निम्नलिखित तरीके से उनके बंदरगाहों (डॉकटर पर -p विकल्प का उपयोग करके) के साथ कुछ इंटरफेस प्रकाशित करने जा रहे हैं।

  • 8400 (आरपीसी)
  • 8500 (HTTP)
  • 8600 (DNS)

किए गए पुल के अनुसार, हम होस्टनाम का नाम भी सेट करने जा रहे हैं node1आप इसका उपयोग करके अपनी इच्छित किसी भी चीज़ में बदल सकते हैं -h flag नीचे दिखाए गए अनुसार स्वयं के कुछ होस्टनाम के साथ।

$ docker run -p 8400:8400 -p 8500:8500 -p 8600:53/udp -h node1 progrium/consul
-server -bootstrap

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

आप कांसुल का उपयोग करके यूआई मोड को भी सक्षम कर सकते हैं -

$ docker run -p 8400:8400 -p 8500:8500 -p 8600:53/udp -h node1 progrium/consul
-server -bootstrap -ui-dir /ui

आप यूआई आधारित आउटपुट की जांच कर सकते हैं http://localhost:8500। निम्नलिखित स्क्रीनशॉट आपको यूआई आधारित आउटपुट के बारे में बेहतर विचार देता है।

विभिन्न नोड्स पर विभिन्न docker कंटेनरों पर कॉन्सल का उपयोग करने के लिए, हम विभिन्न नोड्स पर निम्न कमांड चला सकते हैं -

नोड 1 पर

$ docker run -d --name node1 -h node1 progrium/consul -server -bootstrap-expect 3

कहाँ पे, -bootstrap-expect 3 इसका मतलब है कि कॉन्सल सर्वर तब तक इंतजार करेगा जब तक कि 3 बूटर्स स्व-बूटस्ट्रैपिंग से पहले जुड़े और एक कामकाजी क्लस्टर नहीं बन जाते।

किसी भी आगे जाने से पहले, हमें कंटेनर का निरीक्षण करके कंटेनर का आंतरिक आईपी प्राप्त करना होगा। हमारे उपयोग, मामले के उद्देश्य के लिए, हम घोषणा करने जा रहे हैं$ JOIN_IP

$ JOIN_IP = "$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1)"

नोड 2 पर

तो, चलिए Node2 को शुरू करते हैं और इसे ऊपर दिए गए प्रोग्राम में घोषित चर का उपयोग करके Node1 में शामिल होने के लिए कहते हैं।

$docker run -d --name node2 -h node2 progrium/consul -server -join $JOIN_IP

नोड 3 पर

$ docker run -d --name node3 -h node3 progrium/consul -server -join $JOIN_IP

सर्विस डिस्कवरी के लिए बिल्डिंग रजिस्ट्रार

पंजीयक स्वचालित रूप से किसी भी डॉकटर कंटेनर के लिए रजिस्टरों और डेरेगिस्ट सेवाओं का निरीक्षण करता है, जैसे ही वे ऑनलाइन आते हैं। वर्तमान में हम जिस रजिस्ट्रार का उपयोग करने जा रहे हैं, वह प्लग करने योग्य सेवा रजिस्ट्रियों का समर्थन करता है, जिसमें वर्तमान में शामिल हैConsul, Etcd तथा SkyDNS2। जब हम नेटवर्क पर विभिन्न सेवाओं के साथ बातचीत कर रहे हों तो रजिस्ट्रार के उपयोग की अत्यधिक अनुशंसा की जाती है।

$ docker pull gliderlabs/registrator:latest

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

$ docker run -d \
--name = registrator \
--net = host \
--volume = /var/run/docker.sock:/tmp/docker.sock \
gliderlabs/registrator:latest \
 consul://localhost:8500

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

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

$ docker ps -a

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

आप निम्न कमांड का उपयोग करके रजिस्ट्रार के लॉग भी देख सकते हैं।

$ docker logs registrator

Rkt और घुमंतू का उपयोग करना

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

कॉन्सल के लिए, हम रस्क कुलसचिव का उपयोग कंसुल के साथ सेवा की खोज पर काम करने के लिए कर सकते हैं। यह विशेष पंजीयक परियोजना, जो कि रक के लिए कवर की गई है, विकास के अधीन है और हैnot recommended for production level use

आप जाँच कर सकते हैं कि क्या rkt स्थापित है या नहीं, इसके पथ पर जाकर और निम्न कमांड को चलाकर।

$ ./rkt

आप आउटपुट को जांचने के लिए देख सकते हैं, अगर यह सही ढंग से स्थापित है या नहीं जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Rkt और कंसुल की कोशिश करने के लिए कृपया देखें - https://github.com/r3boot/rkt-registrator।

खानाबदोश उपकरण

सबसे अधिक इस्तेमाल किया जाने वाला और पसंदीदा विकल्प नोमड टूल है। नोमैड मशीनों के एक समूह को प्रबंधित करने और उन पर एप्लिकेशन चलाने के लिए एक उपकरण है। यह समान हैMesos या Kubernetes। डिफ़ॉल्ट रूप से, घुमंतू डॉकर और rkt ड्राइवर को अपने भीतर समाहित करता है। इसलिए, यदि आप कांसुल के साथ कंटेनरों की बड़े पैमाने पर तैनाती की तलाश कर रहे हैं। खानाबदोश इसका एक अच्छा समाधान हो सकता है। देखें -https://www.nomadproject.io/docs/drivers/rkt.html घुमंतू के बारे में अधिक जानकारी के लिए।