कठपुतली - पर्यावरण

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

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

कठपुतली मानक उत्पादन, परीक्षण और विकास पर्यावरण विन्यास के साथ चिपके रहने की सिफारिश करता है, हालांकि, यहां यह उपयोगकर्ता को आवश्यकता के अनुसार कस्टम वातावरण बनाने का लाभ भी प्रदान करता है।

पर्यावरण लक्ष्य

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

कठपुतली मास्टर पर पर्यावरण का उपयोग करना

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

कठपुतली के वातावरण को सर्वर के कठपुतली से पूर्व-पर्यावरण अनुभागों को जोड़कर और प्रत्येक पर्यावरण के लिए अलग-अलग कॉन्फ़िगरेशन स्रोत का चयन करके लागू किया जाता है। इन प्री-एनवायरनमेंट सेक्शंस का इस्तेमाल मुख्य सेक्शन के लिए किया जाता है।

[main] 
manifest = /usr/testing/puppet/site.pp 
modulepath = /usr/testing/puppet/modules 
[development] 
manifest = /usr/testing/puppet/development/site.pp 
modulepath = /usr/testing/puppet/development/modules

उपरोक्त कोड में, विकास के वातावरण में कोई भी ग्राहक निर्देशिका में स्थित site.pp मेनिफ़ेस्ट फ़ाइल का उपयोग करेगा /usr/share/puppet/development और कठपुतली में किसी भी मॉड्यूल के लिए खोज करेंगे /usr/share/puppet/development/modules directory

किसी भी वातावरण के साथ या उसके बिना चलने वाली कठपुतली साइट.पैप फाइल और मुख्य विन्यास अनुभाग में प्रकट और मॉड्यूलपथ मानों में निर्दिष्ट निर्देशिका के लिए डिफ़ॉल्ट होगी।

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

निम्नलिखित पैरामीटर हैं।

  • Modulepath- कठपुतली में, एक बुनियादी मानक मोड के रूप में एक मानक मॉड्यूल निर्देशिका होना सबसे अच्छा है जो सभी पर्यावरण साझा करते हैं और फिर एक पूर्व-पर्यावरण निर्देशिका जहां कस्टम मॉड्यूल संग्रहीत किया जा सकता है। मॉड्यूल पथ वह स्थान है जहां कठपुतली पर्यावरण से संबंधित सभी कॉन्फ़िगरेशन फ़ाइलों की तलाश करती है।

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

  • Manifest - यह परिभाषित करता है कि एंट्रीपॉइंट स्क्रिप्ट के रूप में किस कॉन्फ़िगरेशन का उपयोग करना है।

कई मॉड्यूल के साथ, कठपुतली विन्यास के लिए प्रतिरूपकता प्राप्त करने में मदद करते हैं। एक कठपुतली में कई वातावरणों का उपयोग कर सकते हैं, जो बहुत बेहतर तरीके से काम करता है अगर कोई बहुत हद तक मॉड्यूल पर निर्भर करता है। मॉड्यूल में परिवर्तनों को एनकैप्सुलेट करके वातावरण में परिवर्तन को स्थानांतरित करना आसान है। फ़ाइल सर्वर एक पर्यावरण विशिष्ट मॉड्यूल पथ का उपयोग करता है; यदि कोई अलग-अलग आरोहित निर्देशिकाओं के बजाय मॉड्यूल से फ़ाइल सेवा करता है, तो यह वातावरण पर्यावरण-विशिष्ट फ़ाइलों को प्राप्त करने में सक्षम होगा और अंततः वर्तमान वातावरण भी प्रकट फ़ाइल के भीतर $ पर्यावरण चर में उपलब्ध होगा।

ग्राहकों का माहौल तय करना

पर्यावरण कॉन्फ़िगरेशन से संबंधित सभी कॉन्फ़िगरेशन कठपुतली.कॉन्फ़ फ़ाइल पर किए जाते हैं। पपेट क्लाइंट को किस वातावरण का उपयोग करना चाहिए, यह निर्दिष्ट करने के लिए, ग्राहक की कठपुतली.कॉन्फ़ फ़ाइल में पर्यावरण कॉन्फ़िगरेशन चर के लिए कोई मान निर्दिष्ट कर सकता है।

[puppetd] 
environment = Testing

कॉन्फ़िगरेशन फ़ाइल में उपरोक्त परिभाषा परिभाषित करती है कि कॉन्फ़िगरेशन फ़ाइल किस वातावरण में हमारे परीक्षण में है।

कोई भी कमांड लाइन पर इसे निर्दिष्ट कर सकता है -

#puppetd -–environment = testing

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

कठपुतली खोज पथ

कठपुतली को लक्षित मशीन पर कौन सा कॉन्फ़िगरेशन लागू करना है, यह निर्धारित करने के लिए कठपुतली एक सरल खोज पथ का उपयोग करती है। उसी तरह, कठपुतली में खोज पथ बहुत उपयोगी है जब यह उचित मूल्यों को लेने की कोशिश कर रहा है जिसे लागू करने की आवश्यकता है। नीचे सूचीबद्ध कई स्थान हैं जहाँ कठपुतली उन मूल्यों की खोज करता है जिन्हें लागू करने की आवश्यकता है।

  • कमांड लाइन में निर्दिष्ट मूल्य
  • एक पर्यावरण-विशिष्ट अनुभाग में निर्दिष्ट मान
  • निष्पादन योग्य-विशिष्ट अनुभाग में निर्दिष्ट मान
  • मुख्य अनुभाग में निर्दिष्ट मान