SaltStack - अवलोकन
इस अध्याय में, हम साल्टस्टैक की मूल बातें जानेंगे। साल्टस्टैक की दूरस्थ निष्पादन क्षमताएं प्रशासक को एक लचीली लक्ष्यीकरण प्रणाली के साथ समानांतर में विभिन्न मशीनों पर कमांड चलाने की अनुमति देती हैं। नमक विन्यास प्रबंधन एक दिए गए नीति के अनुसार बुनियादी ढांचे के घटकों को जल्दी, बहुत आसानी से, लचीले ढंग से और सुरक्षित रूप से लाने के लिए एक मास्टर-मिनियन मॉडल स्थापित करता है।
साल्टस्टैक क्या है?
नमक एक बहुत शक्तिशाली स्वचालन ढांचा है। नमक वास्तुकला दूरस्थ रूप से कमांड निष्पादित करने के विचार पर आधारित है। सभी नेटवर्किंग दूरस्थ निष्पादन के कुछ पहलू के आसपास डिज़ाइन की गई हैं। यह एक पूछ के रूप में सरल हो सकता हैRemote Web Serverएक स्थैतिक सर्वर के खिलाफ कमांड को अंतःक्रियात्मक रूप से जारी करने के लिए शेल सत्र का उपयोग करके स्थैतिक वेब पेज या जटिल के रूप में प्रदर्शित करना। नमक अधिक जटिल प्रकार के दूरस्थ निष्पादन में से एक का एक उदाहरण है।
नमक को उपयोगकर्ताओं को स्पष्ट रूप से लक्षित करने और कई मशीनों को सीधे आदेश जारी करने की अनुमति देने के लिए डिज़ाइन किया गया है। नमक एक मास्टर के विचार के आसपास आधारित है, जो एक या अधिक को नियंत्रित करता हैMinions। कमांड आमतौर पर मास्टर से मिनियन के एक लक्षित समूह को जारी किए जाते हैं, जो तब कमांड में निर्दिष्ट कार्यों को निष्पादित करते हैं और फिर परिणामी डेटा को मास्टर को वापस करते हैं। एक मास्टर और minions के बीच संचार पर होते हैंZeroMQ message bus।
साल्टस्टैक मॉड्यूल समर्थित मिनियन ऑपरेटिंग सिस्टम के साथ संचार करता है। Salt Masterडिफ़ॉल्ट रूप से लिनक्स पर चलता है, लेकिन कोई भी ऑपरेटिंग सिस्टम एक मिनियन हो सकता है, और वर्तमान में विंडोज, वीएमवेयर वीस्फेयर और बीएसडी यूनिक्स वेरिएंट अच्छी तरह से समर्थित हैं। नमक मास्टर और मंत्री संवाद करने के लिए कुंजियों का उपयोग करते हैं। जब कोई मिनियन पहली बार किसी मास्टर से जुड़ता है, तो यह स्वचालित रूप से मास्टर पर चाबियाँ जमा करता है। SaltStack भी प्रदान करता हैSalt SSH, जो "एजेंट कम" सिस्टम प्रबंधन प्रदान करता है।
SaltStack के लिए की जरूरत है
SaltStack गति और पैमाने के लिए बनाया गया है। यही कारण है कि इसका उपयोग लिंक्डइन, विकीमीडिया और Google पर दसियों हज़ारों सर्वरों के साथ बड़े इन्फ्रास्ट्रक्चर को प्रबंधित करने के लिए किया जाता है।
कल्पना करें कि आपके पास कई सर्वर हैं और उन सर्वरों पर काम करना चाहते हैं। आपको हर एक पर लॉगिन करना होगा और उन चीजों को एक-एक करके एक बार में करना होगा और फिर आप सॉफ्टवेयर को स्थापित करने और फिर कुछ विशिष्ट मानदंडों के आधार पर उस सॉफ़्टवेयर को कॉन्फ़िगर करने जैसी जटिल चीजें करना चाह सकते हैं।
हमें मान लें कि आपके पास दस या शायद 100 सर्वर भी हैं। प्रत्येक सर्वर पर व्यक्तिगत रूप से एक समय में एक लॉगिंग की कल्पना करें, उन 100 मशीनों पर समान कमांड जारी करें और फिर सभी 100 मशीनों पर कॉन्फ़िगरेशन फ़ाइलों को संपादित करना बहुत ही थकाऊ काम बन जाता है। उन मुद्दों को दूर करने के लिए, आप एक बार में केवल एक ही कमांड टाइप करके अपने सभी सर्वरों को अपडेट करना पसंद करेंगे। साल्टस्टैक आपको ऐसी सभी समस्याओं का समाधान प्रदान करता है।
साल्टस्टैक की विशेषताएं
साल्टस्टैक एक ओपन-सोर्स कॉन्फ़िगरेशन प्रबंधन सॉफ्टवेयर और रिमोट निष्पादन इंजन है। नमक एक कमांड-लाइन टूल है। जबकि पायथन में लिखा गया है, साल्टस्टैक कॉन्फ़िगरेशन प्रबंधन भाषा अज्ञेय और सरल है। नमक मंच SSH प्रोटोकॉल के माध्यम से कमांड निष्पादित करने के लिए पुश मॉडल का उपयोग करता है। डिफ़ॉल्ट कॉन्फ़िगरेशन सिस्टम हैYAML तथा Jinja templates। नमक मुख्य रूप से प्रतिस्पर्धा कर रहा हैPuppet, Chef तथा Ansible।
अन्य प्रतिस्पर्धी उपकरणों की तुलना में नमक कई सुविधाएँ प्रदान करता है। इन महत्वपूर्ण विशेषताओं में से कुछ नीचे सूचीबद्ध हैं।
Fault tolerance- साल्ट मिनियंस सभी उपलब्ध मास्टर्स की एक यिम्ल सूची के रूप में मास्टर कॉन्फ़िगरेशन पैरामीटर को कॉन्फ़िगर करके एक समय में कई मास्टर्स से जुड़ सकते हैं। कोई भी मास्टर साल्ट इन्फ्रास्ट्रक्चर को कमांड दे सकता है।
Flexible- साल्ट का संपूर्ण प्रबंधन दृष्टिकोण बहुत लचीला है। यह सबसे लोकप्रिय सिस्टम प्रबंधन मॉडल जैसे कि एजेंट और सर्वर, एजेंट-केवल, सर्वर-केवल या उपरोक्त सभी एक ही वातावरण में पालन करने के लिए लागू किया जा सकता है।
Scalable Configuration Management - साल्टस्टैक को प्रति मास्टर दस हजार मिनियन को संभालने के लिए डिज़ाइन किया गया है।
Parallel Execution model - नमक एक समानांतर तरीके से रिमोट सिस्टम को निष्पादित करने के लिए आदेशों को सक्षम कर सकता है।
Python API - नमक एक सरल प्रोग्रामिंग इंटरफ़ेस प्रदान करता है और इसे विभिन्न अनुप्रयोगों के लिए ढालना आसान बनाने के लिए मॉड्यूलर और आसानी से एक्स्टेंसिबल होने के लिए डिज़ाइन किया गया था।
Easy to Setup - नमक सेटअप करना आसान है और एकल रिमोट निष्पादन वास्तुकला प्रदान करता है जो किसी भी सर्वर की विभिन्न आवश्यकताओं को प्रबंधित कर सकता है।
Language Agnostic - साल्ट स्टेट कॉन्फिगरेशन फाइल्स, टेम्प्लेटिंग इंजन या फाइल टाइप किसी भी प्रकार की भाषा को सपोर्ट करता है।
साल्टस्टैक के लाभ
सरल होने के साथ-साथ एक सुविधा संपन्न प्रणाली के कारण, नमक कई लाभ प्रदान करता है और उन्हें नीचे संक्षेप में प्रस्तुत किया जा सकता है -
Robust - नमक शक्तिशाली और मजबूत विन्यास प्रबंधन ढांचा है और हजारों प्रणालियों के आसपास काम करता है।
Authentication - नमक प्रमाणीकरण के लिए सरल SSH कुंजी जोड़े का प्रबंधन करता है।
Secure - नमक एक एन्क्रिप्टेड प्रोटोकॉल का उपयोग करके सुरक्षित डेटा का प्रबंधन करता है।
Fast - नमक एक बहुत तेज़, हल्के संचार वाली बस है, जो रिमोट एक्ज़ीक्यूशन इंजन की नींव प्रदान करती है।
Virtual Machine Automation - ऑटोमेशन के लिए साल्ट पुरी क्लाउड कंट्रोलर क्षमता का उपयोग किया जाता है।
Infrastructure as data, not code - नमक एक सरल तैनाती, मॉडल संचालित कॉन्फ़िगरेशन प्रबंधन और कमांड निष्पादन ढांचा प्रदान करता है।
ZeroMQ का परिचय
Salt पर आधारित है ZeroMQपुस्तकालय और यह एक एम्बेड करने योग्य नेटवर्किंग लाइब्रेरी है। यह हल्का और एक तेज संदेश भेजने वाला पुस्तकालय है। मूल कार्यान्वयन में हैC/C++ और सहित कई भाषाओं के लिए देशी कार्यान्वयन Java तथा .Net उपलब्ध है।
ZeroMQ ब्रोकर-कम सहकर्मी संदेश प्रसंस्करण है। ZeroMQ आपको एक जटिल संचार प्रणाली को आसानी से डिजाइन करने की अनुमति देता है।
ZeroMQ निम्नलिखित पांच बुनियादी पैटर्न के साथ आता है -
Synchronous Request/Response - एक अनुरोध भेजने और प्रत्येक भेजे गए प्रत्येक के लिए बाद के उत्तर प्राप्त करने के लिए उपयोग किया जाता है।
Asynchronous Request/Response- अनुरोधकर्ता अनुरोध संदेश भेजकर बातचीत शुरू करता है और प्रतिक्रिया संदेश का इंतजार करता है। प्रदाता आने वाले अनुरोध संदेशों का इंतजार करता है और प्रतिक्रिया संदेशों के साथ जवाब देता है।
Publish/Subscribe - एक एकल प्रक्रिया (जैसे प्रकाशक) से कई प्राप्तकर्ताओं (जैसे ग्राहक) से डेटा वितरित करने के लिए उपयोग किया जाता है।
Push/Pull - कनेक्टेड नोड्स को डेटा वितरित करने के लिए उपयोग किया जाता है।
Exclusive Pair - एक जोड़ी बनाने, दो साथियों को एक साथ जोड़ने के लिए उपयोग किया जाता है।
ZeroMQ क्लस्टर, क्लाउड और अन्य मल्टी सिस्टम वातावरण के बीच संदेशों के आदान-प्रदान के लिए एक अत्यधिक लचीला नेटवर्किंग उपकरण है। ZeroMQ हैdefault transport library साल्टस्टैक में प्रस्तुत किया गया।