कठपुतली - कोडिंग स्टाइल

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

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

मौलिक इकाइयाँ

कठपुतली कई मौलिक कोडिंग शैलियों का उपयोग करती है जो समझना और प्रबंधित करना आसान है। निम्नलिखित कुछ की एक सूची है।

साधन

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

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

फ़ाइल के लिए नमूना कठपुतली संसाधन

निम्नलिखित कमांड में, हम किसी विशेष फ़ाइल के लिए अनुमति निर्दिष्ट करने का प्रयास कर रहे हैं।

file {  
   '/etc/passwd': 
   owner => superuser, 
   group => superuser, 
   mode => 644, 
}

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

शीर्षक में जोड़ में स्थानीय नाम निर्दिष्ट करना

file { 'sshdconfig': 
   name => $operaSystem ? { 
      solaris => '/usr/local/etc/ssh/sshd_config', 
      default => '/etc/ssh/sshd_config', 
   }, 
   owner => superuser, 
   group => superuser, 
   mode => 644, 
}

शीर्षक का उपयोग करके, जो हमेशा एक ही होता है OS से संबंधित तर्क को दोहराए बिना कॉन्फ़िगरेशन में फ़ाइल संसाधन को संदर्भित करना बहुत आसान है।

एक अन्य उदाहरण एक सेवा का उपयोग किया जा सकता है जो एक फ़ाइल पर निर्भर करता है।

service { 'sshd': 
   subscribe => File[sshdconfig], 
}

इस निर्भरता के साथ, sshd सेवा हमेशा एक बार पुनः आरंभ होगी sshdconfigफ़ाइल परिवर्तन। यहाँ याद रखने वाली बात यह हैFile[sshdconfig] फ़ाइल के रूप में निचले मामले में एक घोषणा है लेकिन अगर हम इसे बदलते हैं FILE[sshdconfig] तब यह एक संदर्भ होता।

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

हमारे पास संसाधन निर्भरता को प्रबंधित करने की क्षमता भी है जो कई रिश्तों को प्रबंधित करने में मदद करता है।

service { 'sshd': 
   require => File['sshdconfig', 'sshconfig', 'authorized_keys']
}

Metaparameters

पुटपेट में मेटापैरमीटर को वैश्विक मापदंडों के रूप में जाना जाता है। मेटापरमीटर की प्रमुख विशेषताओं में से एक है, यह पपेट में किसी भी प्रकार के संसाधन के साथ काम करता है।

संसाधन डिफ़ॉल्ट

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

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

Exec { path => '/usr/bin:/bin:/usr/sbin:/sbin' } 
exec { 'echo Testing mataparamaters.': }

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

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

संसाधन संग्रह

एकत्रीकरण चीजों को एक साथ इकट्ठा करने की विधि है। कठपुतली एकत्रीकरण की एक बहुत शक्तिशाली अवधारणा का समर्थन करता है। कठपुतली में समूहन संसाधन के लिए एकत्रीकरण का उपयोग किया जाता है जो कठपुतली की मूलभूत इकाई है। कठपुतली में एकत्रीकरण की इस अवधारणा को दो शक्तिशाली तरीकों के रूप में जाना जाता हैclasses तथा definition

कक्षाएं और परिभाषा

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

दूसरी ओर परिभाषा का उपयोग एक नोड पर कई बार किया जा सकता है। वे उसी तरह काम करते हैं जैसे किसी ने भाषा का उपयोग करके अपना खुद का कठपुतली टाइप बनाया हो। वे हर बार अलग-अलग इनपुट के साथ कई बार उपयोग करने के लिए बनाए जाते हैं। इसका मतलब है कि कोई परिभाषा में परिवर्तनशील मान पारित कर सकता है।

वर्ग और परिभाषा के बीच अंतर

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

कक्षाओं

कठपुतली में कक्षाओं को कक्षा के कीवर्ड का उपयोग करके पेश किया जाता है और उस विशेष वर्ग की सामग्री को घुंघराले ब्रेस के अंदर लपेटा जाता है जैसा कि निम्नलिखित उदाहरण में दिखाया गया है।

class unix { 
   file { 
      '/etc/passwd': 
      owner => 'superuser', 
      group => 'superuser', 
      mode => 644; 
      '/etc/shadow': 
      owner => 'vipin', 
      group => 'vipin', 
      mode => 440; 
   } 
}

निम्नलिखित उदाहरण में, हमने कुछ छोटे हाथ का उपयोग किया है जो उपरोक्त के समान है।

class unix { 
   file { 
      '/etc/passwd': 
      owner => 'superuser', 
      group => 'superuser', 
      mode => 644; 
   }  
   
   file {'/etc/shadow': 
      owner => 'vipin', 
      group => 'vipin', 
      mode => 440; 
   } 
}

कठपुतली कक्षाओं में वंशानुक्रम

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

class superclass inherits testsubclass { 
   File['/etc/passwd'] { group => wheel } 
   File['/etc/shadow'] { group => wheel } 
}

यदि मूल वर्ग में निर्दिष्ट कुछ तर्क को पूर्ववत करने की आवश्यकता है, तो हम उपयोग कर सकते हैं undef command

class superclass inherits testsubcalss { 
   File['/etc/passwd'] { group => undef } 
}

इनहेरिटेंस का उपयोग करने का वैकल्पिक तरीका

class tomcat { 
   service { 'tomcat': require => Package['httpd'] } 
} 
class open-ssl inherits tomcat { 
   Service[tomcat] { require +> File['tomcat.pem'] } 
}

कठपुतली में नेस्टेड क्लास

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

class testclass { 
   class nested { 
      file {  
         '/etc/passwd': 
         owner => 'superuser', 
         group => 'superuser', 
         mode => 644; 
      } 
   } 
} 
class anotherclass { 
   include myclass::nested 
}

परिमित वर्ग

कठपुतली में, कक्षाएं एक कक्षा में मापदंडों को पारित करने की अनुमति देने के लिए अपनी कार्यक्षमता का विस्तार कर सकती हैं।

एक कक्षा में एक पैरामीटर पास करने के लिए, कोई निम्नलिखित निर्माण का उपयोग कर सकता है -

class tomcat($version) { 
   ... class contents ... 
}

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

node webserver { 
   class { tomcat: version => "1.2.12" } 
}

डिफ़ॉल्ट मान वर्ग में पैरामीटर के रूप में

class tomcat($version = "1.2.12",$home = "/var/www") { 
   ... class contents ... 
}

स्टेज चलाएं

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

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

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

कठपुतली घोषणा के साथ अतिरिक्त चरणों की घोषणा

stage { "first": before => Stage[main] } 
stage { "last": require => Stage[main] }

एक बार जब चरणों को घोषित कर दिया जाता है, तो एक वर्ग मंच का उपयोग करते हुए मुख्य के अलावा अन्य चरण से जुड़ा हो सकता है।

class { 
   "apt-keys": stage => first; 
   "sendmail": stage => main; 
   "apache": stage => last; 
}

प्रथम श्रेणी-कुंजी से जुड़े सभी संसाधन पहले चलेंगे। सेंडमेल में सभी संसाधन मुख्य वर्ग होंगे और अपाचे से जुड़े संसाधन अंतिम चरण होंगे।

परिभाषाएं

कठपुतली में, किसी भी प्रकट फ़ाइल में संसाधनों का संग्रह या तो कक्षाओं या परिभाषाओं द्वारा किया जाता है। पपेट में एक वर्ग के लिए परिभाषाएं बहुत हद तक समान हैं लेकिन उन्हें एक के साथ पेश किया गया हैdefine keyword (not class)और वे तर्क का समर्थन करते हैं विरासत का नहीं। वे अलग-अलग मापदंडों के साथ एक ही सिस्टम पर कई बार चल सकते हैं।

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

define perforce_repo($path) { 
   exec {  
      "/usr/bin/svnadmin create $path/$title": 
      unless => "/bin/test -d $path", 
   } 
} 
svn_repo { puppet_repo: path => '/var/svn_puppet' } 
svn_repo { other_repo: path => '/var/svn_other' }

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

मॉड्यूल

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

नोड्स

नोड्स बहुत ही सरल शेष चरण हैं जो हम कैसे परिभाषित करते हैं कि हम उन निर्देशों को पूरा करने के लिए किन मशीनों को चुना गया है ("यह एक वेबसर्वर जैसा दिखता है") है।

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

नोड नाम एक छोटा होस्ट नाम या पूरी तरह से योग्य डोमेन नाम (FQDN) हो सकता है।

node 'www.vipin.com' { 
   include common 
   include apache, squid 
}

उपरोक्त परिभाषा www.vipin.com नामक एक नोड बनाती है और इसमें आम, अपाचे और स्क्विड क्लैसे शामिल हैं

हम प्रत्येक कॉन्फ़िगरेशन को कॉमा के साथ अलग करके एक ही कॉन्फ़िगरेशन को विभिन्न नोड्स में भेज सकते हैं।

node 'www.testing.com', 'www.testing2.com', 'www3.testing.com' { 
   include testing 
   include tomcat, squid 
}

मिलान नोड्स के लिए नियमित अभिव्यक्ति

node /^www\d+$/ { 
   include testing 
}

नोड इनहेरिटेंस

नोड सीमित विरासत मॉडल का समर्थन करता है। कक्षाओं की तरह, नोड्स केवल एक दूसरे नोड से विरासत में मिल सकते हैं।

node 'www.testing2.com' inherits 'www.testing.com' { 
   include loadbalancer 
}

उपरोक्त कोड में, www.testing2.com एक अतिरिक्त भारोत्तोलक वर्ग के अलावा www.testing.com से सभी कार्यात्मकताओं को विरासत में मिला है।

उन्नत समर्थित सुविधाएँ

Quoting- ज्यादातर मामलों में, हमें कठपुतली में एक स्ट्रिंग उद्धृत करने की आवश्यकता नहीं है। किसी भी अक्षर से शुरू होने वाले किसी भी अल्फा न्यूमेरिक स्ट्रिंग को उद्धृत किए बिना छोड़ा जाना है। हालांकि, किसी भी गैर-नकारात्मक मूल्यों के लिए एक स्ट्रिंग को उद्धृत करना हमेशा सबसे अच्छा अभ्यास होता है।

उद्धरण के साथ परिवर्तनीय प्रक्षेप

अब तक हमने परिभाषा के संदर्भ में चर का उल्लेख किया है। यदि किसी को स्ट्रिंग के साथ उन चर का उपयोग करने की आवश्यकता है, तो दोहरे उद्धरण चिह्नों का उपयोग करें, एकल उद्धरणों का नहीं। सिंगल कोट्स स्ट्रिंग कोई वैरिएबल इंटरपोलेशन नहीं करेंगे, डबल कोट्स स्ट्रिंग करेंगे। वेरिएबल को ब्रैकेट में रखा जा सकता है{} जो उन्हें एक साथ उपयोग करने में आसान और समझने में आसान बनाता है।

$value = "${one}${two}"

सर्वोत्तम अभ्यास के रूप में, किसी को उन सभी तारों के लिए एकल उद्धरणों का उपयोग करना चाहिए जिन्हें स्ट्रिंग प्रक्षेप की आवश्यकता नहीं है।

पूंजीकरण

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

  • Referencing- यह पहले से निर्मित संसाधन को संदर्भित करने का तरीका है। यह मुख्य रूप से निर्भरता उद्देश्यों के लिए उपयोग किया जाता है, किसी को संसाधन के नाम को भुनाना है। उदाहरण, आवश्यकता => फ़ाइल [sshdconfig]

  • Inheritance- उपवर्ग से मूल वर्ग के लिए सेटिंग ओवरराइड करते समय, संसाधन नाम के ऊपरी केस संस्करण का उपयोग करें। निचले मामले के संस्करण का उपयोग करने के परिणामस्वरूप त्रुटि होगी।

  • Setting Default Attribute Value - बिना किसी शीर्षक के पूंजीकृत संसाधन का उपयोग संसाधन के डिफ़ॉल्ट को सेट करने के लिए काम करता है।

सरणियों

कठपुतली कई क्षेत्रों में सरणियों के उपयोग की अनुमति देता है [एक, दो, तीन]।

कई प्रकार के सदस्य, जैसे मेजबान परिभाषा में उपनाम उनके मूल्यों में सरणियाँ स्वीकार करते हैं। कई उपनामों वाला एक मेजबान संसाधन कुछ इस प्रकार दिखाई देगा।

host { 'one.vipin.com': 
   alias => [ 'satu', 'dua', 'tiga' ], 
   ip => '192.168.100.1', 
   ensure => present, 
}

उपरोक्त कोड एक होस्ट जोड़ देगा ‘one.brcletest.com’ तीन उपनामों के साथ मेजबान सूची में ‘satu’ ‘dua’ ‘tiga’। यदि कोई एक संसाधन में कई संसाधन जोड़ना चाहता है, तो इसे निम्न उदाहरण में दिखाया जा सकता है।

resource { 'baz': 
   require => [ Package['rpm'], File['testfile'] ], 
}

चर

कठपुतली कई अन्य प्रोग्रामिंग भाषाओं की तरह कई चर का समर्थन करती है। कठपुतली चर के साथ चिह्नित हैं$

$content = 'some content\n' 
file { '/tmp/testing': content => $content }

जैसा कि पहले कहा गया है कि कठपुतली एक घोषित भाषा है, जिसका अर्थ है कि इसका कार्यक्षेत्र और असाइनमेंट नियम अनिवार्य भाषा से अलग हैं। प्राथमिक अंतर यह है कि किसी एक दायरे में परिवर्तनशील परिवर्तन नहीं किया जा सकता है, क्योंकि वे चर के मूल्य को निर्धारित करने के लिए फ़ाइल के क्रम पर निर्भर करते हैं। घोषित भाषा में आदेश मायने नहीं रखता।

$user = root 
file {  
   '/etc/passwd': 
   owner => $user, 
} 

$user = bin 
   file {  
      '/bin': 
      owner => $user, 
      recurse => true, 
   }

चर स्कोप

वैरिएबल स्कोप परिभाषित करता है यदि सभी चर जो परिभाषित हैं, मान्य हैं। नवीनतम विशेषताओं के साथ, पपेट वर्तमान में गतिशील रूप से स्कूप किया गया है, जिसमें पपेट की शर्तों का अर्थ है कि परिभाषित किए गए सभी चरों का उनके स्थान पर मूल्यांकन किया जाता है, न कि वे जिस स्थान पर परिभाषित किए गए हैं।

$test = 'top' 
class Testclass { 
   exec { "/bin/echo $test": logoutput => true } 
} 

class Secondtestclass { 
   $test = 'other' 
   include myclass 
} 

include Secondtestclass

योग्य चर

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

class testclass { 
   $test = 'content' 
} 

class secondtestclass { 
   $other = $myclass::test 
}

उपरोक्त कोड में, $ अन्य चर का मूल्य सामग्री का मूल्यांकन करता है।

सशर्त,

स्थितियां ऐसी स्थितियां हैं जब उपयोगकर्ता परिभाषित स्थिति या आवश्यक स्थिति के संतुष्ट होने पर बयान या कोड के एक सेट को निष्पादित करना चाहता है। कठपुतली दो प्रकार की स्थितियों का समर्थन करती है।

चयनकर्ता स्थिति जो केवल मशीन के सही मूल्य को लेने के लिए परिभाषित संसाधनों के भीतर उपयोग की जा सकती है।

कथन की स्थिति में अधिक व्यापक रूप से उपयोग की जाने वाली स्थितियां हैं जो अतिरिक्त कक्षाओं को शामिल करने में मदद करती हैं जो उपयोगकर्ता उसी प्रकट फ़ाइल में शामिल करना चाहता है। एक वर्ग के भीतर संसाधनों के एक अलग सेट को परिभाषित करें, या अन्य संरचनात्मक निर्णय लें।

चयनकर्ताओं

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

$owner = $Sysoperenv ? { 
   sunos => 'adm', 
   redhat => 'bin', 
   default => undef, 
}

कठपुतली के बाद के संस्करणों में 0.25.0 चयनकर्ताओं को नियमित अभिव्यक्ति के रूप में इस्तेमाल किया जा सकता है।

$owner = $Sysoperenv ? { 
   /(Linux|Ubuntu)/ => 'bin', 
   default => undef, 
}

उपरोक्त उदाहरण में, चयनकर्ता $Sysoperenv मूल्य लिनक्स या उबंटू में से मेल खाता है, तो बिन चयनित परिणाम होगा, अन्यथा उपयोगकर्ता को अपरिभाषित के रूप में सेट किया जाएगा।

कथन की स्थिति

स्टेटमेंट स्टेट पपेट में अन्य प्रकार के सशर्त स्टेटमेंट हैं जो शेल स्क्रिप्ट में स्विच केस स्थिति के समान है। इसमें, केस स्टेटमेंट के कई सेट को परिभाषित किया गया है और दिए गए इनपुट मानों को प्रत्येक स्थिति के विरुद्ध मिलान किया गया है।

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

case $ Sysoperenv { 
   sunos: { include solaris }  
   redhat: { include redhat }  
   default: { include generic}  
}

केस स्टेटमेंट उन्हें कॉमा के साथ अलग करके कई शर्तों को भी निर्दिष्ट कर सकता है।

case $Sysoperenv { 
   development,testing: { include development } testing,production: { include production }
   default: { include generic }  
}

अगर-एल्स स्टेटमेंट

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

if $Filename { 
   file { '/some/file': ensure => present } 
} else { 
   file { '/some/other/file': ensure => present } 
}

कठपुतली का नवीनतम संस्करण परिवर्तनशील अभिव्यक्ति का समर्थन करता है जिसमें यदि अभिव्यक्ति के मूल्य के आधार पर यदि कथन भी शाखा कर सकता है।

if $machine == 'production' { 
   include ssl 
} else { 
   include nginx 
}

कोड में अधिक विविधता प्राप्त करने और जटिल सशर्त संचालन करने के लिए, कठपुतली नेस्टेड का समर्थन करती है, यदि निम्नलिखित कोड में दिखाया गया है।

if $ machine == 'production' { 
   include ssl 
} elsif $ machine == 'testing' { 
   include nginx
} else { 
   include openssl 
}

आभासी संसाधन

वर्चुअल रिसोर्स वो होते हैं जो क्लाइंट को तब तक नहीं भेजे जाते जब तक उसे एहसास न हो।

निम्नलिखित कठपुतली में आभासी संसाधन का उपयोग करने का वाक्य विन्यास है।

@user { vipin: ensure => present }

उपरोक्त उदाहरण में, उपयोगकर्ता विपिन को परिभाषा के रूप में परिभाषित किया गया है कि संग्रह में उपयोग की जाने वाली परिभाषा क्या है।

User <| title == vipin |>

टिप्पणियाँ

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

  • यूनिक्स शैल शैली टिप्पणियाँ। वे अपनी लाइन या अगली लाइन पर हो सकते हैं।
  • मल्टी-लाइन सी-स्टाइल टिप्पणियां।

निम्नलिखित शैल शैली टिप्पणी का एक उदाहरण है।

# this is a comment

निम्नलिखित बहुस्तरीय टिप्पणी का एक उदाहरण है।

/* 
This is a comment 
*/

संचालक वरीयता

कठपुतली ऑपरेटर पूर्वता अधिकांश प्रणालियों में मानक वरीयता के अनुरूप है, उच्चतम से निम्नतम तक।

निम्नलिखित भावों की सूची है

  • ! = नहीं है
  • / = बार और विभाजित करें
  • - + = माइनस, प्लस
  • << >> = बाईं पारी और दाईं पारी
  • ==! = = बराबर नहीं, बराबर
  • > = <=> <= अधिक से अधिक, कम या बराबर, से अधिक, कम से कम

तुलना अभिव्यक्ति

तुलना अभिव्यक्ति का उपयोग तब किया जाता है जब उपयोगकर्ता दिए गए शर्त के संतुष्ट होने पर बयानों के एक सेट को निष्पादित करना चाहता है। तुलना अभिव्यक्तियों में == अभिव्यक्ति का उपयोग करते हुए समानता के लिए परीक्षण शामिल हैं।

if $environment == 'development' { 
   include openssl 
} else { 
   include ssl 
}

न के बराबर उदाहरण

if $environment != 'development' { 
   $otherenvironment = 'testing' 
} else { 
   $otherenvironment = 'production' 
}

अंकगणित अभिव्यक्ति

$one = 1 
$one_thirty = 1.30 
$two = 2.034e-2 $result = ((( $two + 2) / $one_thirty) + 4 * 5.45) - 
   (6 << ($two + 4)) + (0×800 + -9)

बूलियन अभिव्यक्ति

बूलियन अभिव्यक्तियों का उपयोग करना संभव है या, और, और नहीं।

$one = 1 
$two = 2 
$var = ( $one < $two ) and ( $one + 1 == $two )

नियमित अभिव्यक्ति

कठपुतली = (मैच) और ~! (नहीं-मैच) का उपयोग करके नियमित अभिव्यक्ति मिलान का समर्थन करती है।

if $website =~ /^www(\d+)\./ { 
   notice('Welcome web server #$1') 
}

मामले और चयनकर्ता रेगेक्स मैच की तरह प्रत्येक रेगेक्स के लिए सीमित गुंजाइश चर बनाता है।

exec { "Test": 
   command => "/bin/echo now we don’t have openssl installed on machine > /tmp/test.txt", 
   unless => "/bin/which php" 
}

इसी तरह, हम तब तक उपयोग कर सकते हैं, जब तक कि कमांड को हर समय निष्पादित न करें, तब तक कमांड को छोड़कर जब तक कि सफलतापूर्वक बाहर न निकल जाए।

exec { "Test": 
   command => "/bin/echo now we don’t have openssl installed on machine > /tmp/test.txt", 
   unless => "/bin/which php" 
}

टेम्प्लेट के साथ काम करना

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

file { "/etc/tomcat/sites-available/default.conf": 
   ensure => "present", 
   content => template("tomcat/vhost.erb")  
}

संगठन और प्रतिरूपकता को लागू करने के लिए स्थानीय फ़ाइलों से निपटने के दौरान कठपुतली कुछ धारणाएँ बनाती है। कठपुतली मॉड्यूल निर्देशिका के अंदर फ़ोल्डर अपाचे / टेम्पलेट्स के अंदर vhost.erb टेम्पलेट के लिए लग रहा है।

परिभाषित और ट्रिगर सेवा

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

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

service { 'tomcat': 
   ensure => running, 
   enable => true 
}

संसाधनों को परिभाषित करते समय, हमें पुनः आरंभ करने के लिए अधिसूचित विकल्प को शामिल करना होगा।

file { "/etc/tomcat/sites-available/default.conf": 
   ensure => "present", 
   content => template("vhost.erb"), 
   notify => Service['tomcat']  
}