कठपुतली - पर्यावरण विश्वास
कठपुतली में, सभी वातावरण हैं environment.confफ़ाइल। यह फ़ाइल कई डिफ़ॉल्ट सेटिंग्स को ओवरराइड कर सकती है जब भी मास्टर किसी नोड या उस विशेष वातावरण को सौंपे गए सभी नोड्स की सेवा कर रहा हो।
स्थान
कठपुतली में, परिभाषित किए गए सभी वातावरणों के लिए, environment.conf फ़ाइल अपने घर के वातावरण के शीर्ष स्तर पर स्थित है, जो कि प्रकट और मॉड्यूल निर्देशकों के बगल में है। एक उदाहरण पर विचार करते हुए, यदि आपका वातावरण डिफ़ॉल्ट निर्देशिकाओं में है(Vipin/testing/environment), तो परीक्षण पर्यावरण की विन्यास फाइल पर स्थित है Vipin/testing/environments/test/environment.conf।
उदाहरण
# /etc/testingdir/code/environments/test/environment.conf
# Puppet Enterprise requires $basemodulepath; see note below under modulepath". modulepath = site:dist:modules:$basemodulepath
# Use our custom script to get a git commit for the current state of the code:
config_version = get_environment_commit.sh
प्रारूप
कठपुतली में सभी विन्यास फाइल उसी तरह INI-समान प्रारूप का उपयोग करता है। environment.confफ़ाइल उसी INI जैसे प्रारूप का अनुसरण करती है जैसा कि अन्य कठपुतली की तरह करते हैं। फाइल। केवल पर्यावरण के बीच का अंतर ।conf औरpuppet.confis.conf फ़ाइल में [मुख्य] अनुभाग नहीं हो सकता है। वातावरण में सभी सेटिंग्स .conf फ़ाइल किसी भी विन्यास अनुभाग के बाहर होनी चाहिए।
मूल्यों में सापेक्ष पथ
अधिकांश अनुमत सेटिंग्स मान के रूप में फ़ाइल पथ या पथ की सूची को स्वीकार करती हैं। यदि कोई भी पथ प्रासंगिक पथ है, तो वे एक प्रमुख स्लैश या ड्राइव अक्षर के बिना शुरू करते हैं - वे ज्यादातर उस पर्यावरण के मुख्य निर्देशिका के सापेक्ष हल हो जाएंगे।
मूल्यों में प्रक्षेप
एन्वायर्नमेंट.कॉन्फ़ सेटिंग्स फ़ाइल चर के रूप में अन्य सेटिंग्स के मूल्यों का उपयोग करने में सक्षम है। कई उपयोगी चर हैं जिन्हें पर्यावरण में अंतरित किया जा सकता है। फाइल। यहाँ कुछ महत्वपूर्ण चर की एक सूची है -
$basemodulepath- मॉड्यूल पथ सेटिंग्स में निर्देशिकाओं को शामिल करने के लिए उपयोगी। कठपुतली उद्यम उपयोगकर्ता आमतौर पर के इस मूल्य को शामिल करना चाहिएmodulepath चूंकि कठपुतली इंजन मॉड्यूल का उपयोग करता है basemodulepath।
$environment- अपने config_version स्क्रिप्ट के लिए कमांड लाइन तर्क के रूप में उपयोगी। आप इस चर को केवल config_version सेटिंग में इंटरपोल कर सकते हैं।
$codedir - फ़ाइलों का पता लगाने के लिए उपयोगी है।
अनुमत सेटिंग्स
डिफ़ॉल्ट रूप से, कठपुतली पर्यावरण.कॉन्फ़ फ़ाइल केवल विन्यास में चार सेटिंग्स को ओवरराइड करने की अनुमति है।
- Modulepath
- Manifest
- Config_version
- Environment_timeout
Modulepath
यह environment.conf फाइल की प्रमुख सेटिंग्स में से एक है। मॉड्यूलपैथ में परिभाषित सभी निदेशक पपेट द्वारा डिफ़ॉल्ट रूप से लोड किए गए हैं। यह वह पथ स्थान है जहां से कठपुतली अपने मॉड्यूल लोड करती है। एक को स्पष्ट रूप से स्थापित करने की आवश्यकता है। यदि यह उपरोक्त सेटिंग सेट नहीं है, तो कठपुतली में किसी भी वातावरण का डिफ़ॉल्ट मॉड्यूलपथ होगा -
<MODULES DIRECTORY FROM ENVIRONMENT>:$basemodulepath
प्रकट
इसका उपयोग मुख्य मेनिफ़ेस्ट फ़ाइल को परिभाषित करने के लिए किया जाता है, जिसे कठपुतली मास्टर परिभाषित करते समय कैटलॉग का उपयोग करेगा और कैटलॉग को निर्धारित करेगा जो पर्यावरण को कॉन्फ़िगर करने के लिए उपयोग करने वाला है। इसमें, हम एक एकल फाइल, फाइलों की एक सूची, या यहां तक कि एक निर्देशिका को परिभाषित कर सकते हैं जिसमें कई प्रकट फाइलें होती हैं जिन्हें परिभाषित वर्णमाला अनुक्रम में मूल्यांकन और संकलित करने की आवश्यकता होती है।
पर्यावरण में इस सेटिंग को स्पष्ट रूप से परिभाषित करने की आवश्यकता है। फाइल फाइल। यदि नहीं, तो कठपुतली पर्यावरण डिफ़ॉल्ट प्रकट निर्देशिका का उपयोग अपने मुख्य प्रदर्शन के रूप में करेगी।
Config_version
Config_version को कैटलॉग और ईवेंट की पहचान करने के लिए उपयोग किए जाने वाले निश्चित संस्करण के रूप में परिभाषित किया जा सकता है। जब कठपुतली डिफ़ॉल्ट रूप से किसी भी मैनिफ़ेस्ट फ़ाइल को संकलित करती है, तो यह उत्पन्न कैटलॉग के साथ-साथ उन रिपोर्टों के लिए एक कॉन्फ़िगर संस्करण जोड़ती है जो कठपुतली नोड पर कोई भी परिभाषित कैटलॉग लागू करने पर उत्पन्न हो जाती है। कठपुतली उपरोक्त सभी चरणों को पूरा करने के लिए एक स्क्रिप्ट चलाती है और सभी उत्पन्न आउटपुट को config_version के रूप में उपयोग करती है।
पर्यावरण का समय
इसका उपयोग उस समय की मात्रा के बारे में विवरण प्राप्त करने के लिए किया जाता है जो पपेट को किसी दिए गए वातावरण के लिए डेटा लोड करने के लिए उपयोग करना चाहिए। यदि मान कठपुतली.कॉन्फ़ फ़ाइल में परिभाषित किया गया है, तो ये मान डिफ़ॉल्ट टाइमआउट मान को ओवरराइड कर देंगे।
नमूना environment.conf फ़ाइल
[master]
manifest = $confdir/environments/$environment/manifests/site.pp
modulepath = $confdir/environments/$environment/modules
उपरोक्त कोड में $confdir निर्देशिका का पथ है, जहाँ पर्यावरण कॉन्फ़िगरेशन फ़ाइलें स्थित हैं। $environment उस पर्यावरण का नाम है जिसके लिए कॉन्फ़िगरेशन किया जा रहा है।
उत्पादन तैयार पर्यावरण विन्यास फाइल
# The environment configuration file
# The main manifest directory or file where Puppet starts to evaluate code
# This is the default value. Works with just a site.pp file or any other
manifest = manifests/
# The directories added to the module path, looked in first match first used order:
# modules - Directory for external modules, populated by r10k based on Puppetfile
# $basemodulepath - As from: puppet config print basemodulepath modulepath = site:modules:$basemodulepath
# Set the cache timeout for this environment.
# This overrides what is set directly in puppet.conf for the whole Puppet server
# environment_timeout = unlimited
# With caching you need to flush the cache whenever new Puppet code is deployed
# This can also be done manually running: bin/puppet_flush_environment_cache.sh
# To disable catalog caching:
environment_timeout = 0
# Here we pass to one in the control repo the Puppet environment (and git branch)
# to get title and essential info of the last git commit
config_version = 'bin/config_script.sh $environment'