कौंसल - फेलओवर इवेंट्स

इस अध्याय में, हम कंसल में विफलता घटनाओं के बारे में जानेंगे। यह निम्नलिखित कार्यों की सहायता से किया जाएगा -

  • एकल क्लस्टर विफलता
  • जेपसेन परीक्षण
  • एकाधिक क्लस्टर विफलता
  • स्नैपशॉट लेना

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

एकल क्लस्टर विफलता

किसी एक क्लस्टर विफलता में, डेटासेंटर में से किसी एक में रखा क्लस्टर विफल होने लगता है। प्रत्येक मामले में, यह सुनिश्चित करना महत्वपूर्ण है कि विफलता के मामले में सिस्टम न केवल इसे रोक सकता है, बल्कि एक बैकअप भी है जिस पर वह भरोसा कर सकता है। कॉन्सुल फेलओवर घटनाओं को रोकने के लिए, हम कॉन्सुल-अलर्ट नामक कुछ का उपयोग करने जा रहे हैं। मुख्य परियोजना में पाया जा सकता है -https://github.com/AcalephStorage/consul-alerts।

कौंसुल-स्वास्थ्य चेकों पर आधारित सूचनाएं और रिमाइंडर भेजने के लिए कंसुल-अलर्ट एक अत्यधिक उपलब्ध डेमॉन है। यह प्रोजेक्ट लोकलहोस्ट: 9000 पर एक डेमॉन और एपीआई चलाता है और डिफॉल्ट डेटासेंटर (dc1) के साथ लोकल कॉन्सुल एजेंट (लोकलहोस्ट: 8500) से जुड़ता है।

परियोजना के साथ आरंभ करने के दो तरीके हैं। पहली विधि के माध्यम से इसे स्थापित करना हैGO। जिन उपयोगकर्ताओं के पास GO स्थापित और कॉन्फ़िगर किया गया है, वे नीचे दिए गए चरणों का पालन कर सकते हैं -

$ go get github.com/AcalephStorage/consul-alerts
$ go install
$ consul-alerts start

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

$ consul-alerts start --alert-addr = localhost:9000 --consul-addr = localhost:8500
--consul-dc = dc1 --consul-acl-token = ""

दूसरी विधि में डॉकर का उपयोग करने के लिए उपयोगकर्ता शामिल है। दोनों विधियाँ विभिन्न परिदृश्यों में समान रूप से उपयोगी हैं। डॉकर पर कॉन्सुल-अलर्ट का उपयोग करने के लिए, हमें निम्नलिखित कमांड का उपयोग करके डॉकटर हब से छवि को खींचना चाहिए।

$ docker pull acaleph/consul-alerts

डॉकर पद्धति में, हम निम्नलिखित तीन विकल्पों पर विचार कर सकते हैं -

  • कंटेनर में बनाया गया है कि कंसुल एजेंट का उपयोग करना।
  • दूसरे डॉकटर कंटेनर पर चल रहे कौंसल एजेंट का उपयोग करना।
  • रिमोट कॉन्सल इंस्टेंस पर लिंक करने के लिए कॉन्सुल-अलर्ट का उपयोग करना।

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

कंटेनर में बनाया गया है कि कंसुल एजेंट का उपयोग करना

आइए हम निम्नलिखित कमांड का उपयोग करते हुए वाणिज्य दूत शुरू करें -

$ docker run -ti \
   --rm -p 9000:9000 \
   --hostname consul-alerts \
   --name consul-alerts \  
   --entrypoint = /bin/consul \
   acaleph/consul-alerts \
   agent -data-dir /data -server -bootstrap -client = 0.0.0.0

यहाँ, हम आगे निकल रहे हैं entrypoint ध्वज के अनुसार कौंसुल के लिए --entrypoint। इसके साथ, हम क्लाइंट का उपयोग करके उपयोग किए गए पोर्ट का उल्लेख करके बूटस्ट्रैप कर रहे हैं-p flag, data directory /data ध्वज का उपयोग -data-dir और क्लाइंट के रूप में 0.0.0.0।

एक नई टर्मिनल विंडो पर, हम कॉन्सुल-अलर्ट विकल्प शुरू करते हैं।

$ docker exec -ti consul-alerts /bin/consul-alerts start --alertaddr = 0.0.0.0:9000
--log-level = info --watch-events --watch-checks

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

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

दूसरे डॉकटर कंटेनर पर चल रहे कौंसल एजेंट का उपयोग करना

यहां, आप डॉकर कंटेनर पर चलने के लिए किसी भी प्रकार की कॉन्सल इमेज का उपयोग कर सकते हैं। कॉन्सल-अलर्ट इमेज का उपयोग करके, हम कॉन्सुल कंटेनर को कॉन्सुल-अलर्ट कंटेनर के साथ आसानी से लिंक कर सकते हैं। यह प्रयोग किया जाता है--link flag

Note - निम्नलिखित कमांड का उपयोग करने से पहले, कृपया सुनिश्चित करें कि कॉन्सल कंटेनर पहले से ही दूसरे टर्मिनल पर चल रहा है।

$ docker run -ti \
   -p 9000:9000 \
   --hostname consul-alerts \
   --name consul-alerts \
   --link consul:consul \
   acaleph/consul-alerts start \
   --consul-addr=consul:8500 \
   --log-level = info --watch-events --watch-checks

रिमोट कॉन्सल इंस्टेंस पर लिंक करने के लिए कॉन्सुल-अलर्ट का उपयोग करना

यहां, हमें दूरस्थ कंसोल उदाहरण से लिंक करने के लिए कॉन्सुल-अलर्ट का उपयोग करने के लिए निम्न कमांड का उपयोग करना चाहिए।

$ docker run -ti \
   -p 9000:9000 \
   --hostname consul-alerts \
   --name consul-alerts \
   acaleph/consul-alerts start \
   --consul-addr = remote-consul-server.domain.tdl:8500 \
   --log-level = info --watch-events --watch-checks

जेपसेन परीक्षण

जेस्पेन किसी भी सिस्टम में आंशिक सहिष्णुता और नेटवर्किंग का परीक्षण करने के लिए लिखा गया उपकरण है। यह सिस्टम पर कुछ यादृच्छिक संचालन बनाकर सिस्टम का परीक्षण करता है।Jepsen is written in Clojure। दुर्भाग्य से, डेमो के लिए, जेपसेन परीक्षण के लिए डेटाबेस सिस्टम के साथ क्लस्टर गठन का एक विशाल स्तर की आवश्यकता होती है और इसलिए इसे कवर करने की गुंजाइश से बाहर है।

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

टेस्ट रन के अंत में, यह क्लस्टर को ठीक करता है, क्लस्टर के ठीक होने का इंतजार करता है और फिर सत्यापित करता है कि सिस्टम का मध्यवर्ती और अंतिम राज्य अपेक्षित है या नहीं। कुछ अंश यहाँ से लिए गए हैं ।

जेपसेन परीक्षण के बारे में अधिक जानकारी के लिए, इसे यहाँ देखें ।

एकाधिक क्लस्टर विफलता

मल्टीपल क्लस्टर फेलओवर इवेंट के दौरान, कई डेटासेंटर में तैनात क्लस्टर ग्राहक को दी जाने वाली सेवाओं का समर्थन करने में विफल रहते हैं। कॉन्सल हमें यह सुनिश्चित करने में सक्षम बनाता है कि जब ऐसी स्थिति में से एक होता है, तो कॉन्सल में ऐसी विशेषताएं हैं जो आपको इस प्रकार की स्थितियों में सेवाएं सक्षम करने में मदद करती हैं।

ऐसा होने के लिए, हम एक परियोजना के माध्यम से देखेंगे, जो हमें एक क्लस्टर से एक से अधिक समूहों में कांसुल की प्रतिकृति बनाने में मदद करती है। यह परियोजना हमें वाणिज्य दूतावास की प्रतिकृति का उपयोग करते हुए कई कांसुल डेटा केंद्रों में के / वी जोड़े को दोहराने का एक तरीका प्रदान करती है। आप इस हशिकॉर्प परियोजना को देख सकते हैं -https://github.com/hashicorp/consul-replicate। इस परियोजना को आज़माने के लिए कुछ आवश्यक शर्तें शामिल हैं -

  • Golang
  • Docker
  • Consul
  • Git

आइए हम निम्नलिखित आदेशों के साथ आरंभ करें -

Note - निम्नलिखित कमांड चलाने से पहले, सुनिश्चित करें कि आपने अपनी मशीन पर Git को ठीक से स्थापित और कॉन्फ़िगर किया है।

$ git clone - https://github.com/hashicorp/consul-replicate.git

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

$ cd consul-replicate
$ make

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

यदि आपको बाइनरी के निर्माण में कुछ परेशानी हो रही है, तो आप निम्न कमांड का उपयोग करके मैन्युअल रूप से डॉकर चित्रों को खींचने का प्रयास कर सकते हैं -

$ docker pull library/golang:1.7.4

उपर्युक्त कमांड बिन / वाणिज्य-प्रतिकृति बनाएगी, जिसे बाइनरी के रूप में लागू किया जा सकता है। निम्न तालिका उप-आदेशों की पूरी सूची दिखाती है जो इसे कवर करती हैं -

विकल्प विवरण
प्रमाणन मूल प्रमाणीकरण उपयोगकर्ता नाम (और वैकल्पिक पासवर्ड), एक बृहदान्त्र द्वारा अलग किया गया। कोई डिफ़ॉल्ट मूल्य नहीं है।
कौंसुल * पोर्ट के साथ कंसूल उदाहरण का स्थान (एक IP पता या FQDN हो सकता है)।
अधिकतम-बासी किसी क्वेरी की अधिकतम गति। यदि निर्दिष्ट किया गया है, तो कॉन्यूलस सिर्फ नेता के बजाय सभी सर्वरों के बीच काम वितरित करेगा। डिफ़ॉल्ट मान 0 (कोई नहीं) है।
एसएसएल कौंसल से बात करते समय HTTPS का उपयोग करें। सर्वर सुरक्षित कनेक्शन के लिए कॉन्फ़िगर किए जाने वाले वाणिज्य दूतावास सर्वर की आवश्यकता होती है। मूल मूल्य गलत है।
ssl रूप से सत्यापन एसएसएल के माध्यम से कनेक्ट करते समय प्रमाण पत्र सत्यापित करें। इसके लिए -ll के उपयोग की आवश्यकता होती है। डिफ़ॉल्ट मान सत्य है।
syslog Syslog (stdout और stderr के अलावा) में लॉग आउटपुट भेजें। मूल मूल्य गलत है
syslog-सुविधा सिसलॉग भेजते समय उपयोग करने की सुविधा। इसके लिए -syslog के उपयोग की आवश्यकता होती है। डिफ़ॉल्ट LOCAL है
टोकन कौंसल एपीआई टोकन। कोई डिफ़ॉल्ट मूल्य नहीं है।
उपसर्ग * स्रोत उपसर्ग सहित, विकल्प गंतव्य उपसर्ग के साथ, एक बृहदान्त्र द्वारा अलग किया गया ():)। यह विकल्प additive है और इसे दोहराने के लिए कई उपसर्गों के लिए कई बार निर्दिष्ट किया जा सकता है।
निकालना प्रतिकृति के दौरान बाहर करने के लिए एक उपसर्ग। यह विकल्प additive है और इसे बाहर करने के लिए कई उपसर्गों के लिए कई बार निर्दिष्ट किया जा सकता है।
रुको माइनियम (: अधिकतम) प्रतिकृति से पहले स्थिरता की प्रतीक्षा करने के लिए, एक बृहदान्त्र द्वारा अलग किया गया (:)। यदि वैकल्पिक अधिकतम मूल्य छोड़ा जाता है, तो इसे आवश्यक न्यूनतम मूल्य 4x माना जाता है। कोई डिफ़ॉल्ट मूल्य नहीं है।
पुन: प्रयास करें यदि API से संचार करते समय कॉन्यूलस त्रुटि देता है, तो प्रतीक्षा करने के लिए समय की राशि। डिफ़ॉल्ट मान 5 सेकंड है।
कॉन्फ़िग वर्तमान फ़ाइल निर्देशिका के सापेक्ष डिस्क पर कॉन्फ़िगरेशन फ़ाइल या कॉन्फ़िगरेशन फ़ाइलों की निर्देशिका का पथ। सीएलआई पर निर्दिष्ट मान कॉन्फ़िगरेशन फ़ाइल में निर्दिष्ट मूल्यों पर पूर्वता लेते हैं। कोई डिफ़ॉल्ट मूल्य नहीं है।
छांटने का स्तर आउटपुट के लिए लॉग स्तर। यह stdout / stderr लॉगिंग के साथ-साथ syslog लॉगिंग (यदि लागू हो) पर लागू होता है। मान्य मान "डीबग", "जानकारी", "चेतावनी, और" गलत "हैं। डिफ़ॉल्ट मान" चेतावनी "है।
एक बार रन कॉन्सलिट्स को एक बार दोहराएं और बाहर निकलें (डेमन के डिफ़ॉल्ट व्यवहार के विपरीत)। (CLI-मात्र)
संस्करण आउटपुट संस्करण की जानकारी और छोड़ दिया। (CLI-मात्र)

स्नैपशॉट लेना

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

  • स्नैपशॉट सहेजें
  • कॉनसोल स्नैपशॉट एजेंट
  • कंसल स्नैपशॉट का निरीक्षण करें
  • स्नैपशॉट पुनर्स्थापित करें

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

स्नैपशॉट सहेजें

यह आदेश कॉन्सल सर्वर के राज्य के एक परमाणु, पॉइंट-इन-टाइम स्नैपशॉट को पुनः प्राप्त करने के लिए सेट किया गया है, जिसमें कुंजी / मान प्रविष्टियां, सेवा कैटलॉग, तैयार क्वेरी, सत्र और एसीएल शामिल हैं। स्नैपशॉट फ़ाइल नाम में सहेजा गया है।

$ consul snapshot save <name-of-the-file>.snap

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

वर्तमान निर्देशिका में फ़ाइल की उपस्थिति की जाँच करने के लिए, कृपया इसे अपनी वर्तमान निर्देशिका में चलाकर देखें। एक गैर-नेता नोड के मामले में, कृपया निम्न आदेश निष्पादित करें -

$ consul snapshot save -stale <name-of-file>.snap

कंसल स्नैपशॉट एजेंट

यह उप-कमांड एक ऐसी प्रक्रिया शुरू करती है जो कॉन्सुल सर्वरों की स्थिति का स्नैपशॉट लेती है और उन्हें स्थानीय रूप से सहेजती है, या उन्हें एक वैकल्पिक रिमोट स्टोरेज सेवा में धकेल देती है।

कंसल स्नैपशॉट का निरीक्षण करें

इसका उपयोग कौंसल सर्वर की स्थिति के समय-समय पर स्नैपशॉट का निरीक्षण करने के लिए किया जाता है, जिसमें कुंजी / मूल्य प्रविष्टियां, सेवा सूची, तैयार किए गए प्रश्न, सत्र और ACL शामिल हैं। आदेश को निम्नानुसार निष्पादित किया जा सकता है -

Note - याद रखें कि निम्न कमांड केवल डायरेक्टरी में चलाया जा सकता है, जहां स्नैपशॉट सेव किया गया है।

$ consul snapshot save <name-of-the-file>.snap

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

कंसोल स्नैपशॉट को पुनर्स्थापित करें

स्नैपशॉट पुनर्स्थापना आदेश का उपयोग कंसोल सर्वर की स्थिति के समय-समय पर स्नैपशॉट को पुनर्स्थापित करने के लिए किया जाता है, जिसमें कुंजी / मान प्रविष्टियां, सेवा कैटलॉग, तैयार किए गए प्रश्न, सत्र और ACL शामिल हैं। स्नैपशॉट सहेजे गए बैकअप फ़ाइल से पढ़ा जाता है।

Note - याद रखें कि निम्न कमांड केवल उस डायरेक्टरी में चलाया जा सकता है, जहां स्नैपशॉट सेव किया गया है।

$ consul snapshot restore <name-of-the-file>.snap

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

यदि आप AWS के साथ कॉन्सल पर काम कर रहे हैं, तो यह प्रोजेक्ट आपको कुछ समय बचाने में मदद कर सकता है - https://github.com/pshima/consul-snapshot।