कठपुतली - त्वरित गाइड

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

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

कठपुतली प्रणाली की विशेषताएं

कठपुतली की सबसे महत्वपूर्ण विशेषताएं निम्नलिखित हैं।

Idempotency

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

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

क्रॉस-प्लेटफॉर्म

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

कठपुतली - वर्कफ़्लो

कठपुतली सिस्टम पर विन्यास लागू करने के लिए निम्नलिखित वर्कफ़्लो का उपयोग करता है।

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

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

  • पपेट एजेंट तब सिस्टम को वांछित स्थिति में लाने के लिए उन कॉन्फ़िगरेशन को लागू करता है।

  • अंत में, एक बार एक वांछित राज्य में लक्ष्य नोड होने के बाद, यह पपेट मास्टर को एक रिपोर्ट वापस भेजता है, जो कठपुतली मास्टर को यह समझने में मदद करता है कि सिस्टम की वर्तमान स्थिति कहाँ है, जैसा कि कैटलॉग में परिभाषित किया गया है।

कठपुतली - प्रमुख घटक

कठपुतली के प्रमुख घटक निम्नलिखित हैं।

कठपुतली संसाधन

कठपुतली संसाधन किसी विशेष मशीन के मॉडलिंग के लिए प्रमुख घटक हैं। इन संसाधनों का अपना कार्यान्वयन मॉडल है। कठपुतली वांछित अवस्था में किसी विशेष संसाधन को प्राप्त करने के लिए उसी मॉडल का उपयोग करती है।

प्रदाताओं

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

प्रकट

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

मॉड्यूल

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

टेम्पलेट्स

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

Listen <% = @httpd_port %>

इस मामले में httpd_port चर को इस टेम्प्लेट के संदर्भ में परिभाषित किया गया है।

स्थैतिक फ़ाइलें

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

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

कठपुतली मास्टर

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

कठपुतली एजेंट

कठपुतली एजेंट वास्तविक कामकाजी मशीनें हैं जिन्हें कठपुतली मास्टर द्वारा प्रबंधित किया जाता है। उनके पास पपेट एजेंट डेमॉन सेवा चल रही है।

कॉन्फ़िगरेशन रिपॉजिटरी

यह रेपो है जहां सभी नोड्स और सर्वर से संबंधित कॉन्फ़िगरेशन सहेजे जाते हैं और आवश्यकता होने पर खींचे जाते हैं।

तथ्यों

Factsनोड या मास्टर मशीन से संबंधित विवरण हैं, जो मूल रूप से किसी भी नोड की वर्तमान स्थिति का विश्लेषण करने के लिए उपयोग किया जाता है। तथ्यों के आधार पर, किसी भी लक्ष्य मशीन पर परिवर्तन किए जाते हैं। पपेट में पूर्व-परिभाषित और कस्टम तथ्य हैं।

सूची

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

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

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

आवश्यक शर्तें

फैक्टर एकमात्र पूर्व-आवश्यकता है जो साथ नहीं आती है Ohai जो शेफ में मौजूद है।

मानक ओएस लाइब्रेरी

हमें किसी भी अंतर्निहित ओएस के पुस्तकालय का मानक सेट करने की आवश्यकता है। शेष सभी प्रणाली रूबी 1.8.2 + संस्करणों के साथ आती है। निम्नलिखित पुस्तकालय वस्तुओं की सूची है, जिसमें एक ओएस शामिल होना चाहिए।

  • base64
  • cgi
  • digest/md5
  • etc
  • fileutils
  • ipaddr
  • openssl
  • strscan
  • syslog
  • uri
  • webrick
  • webrick/https
  • xmlrpc

कारक स्थापना

जैसा कि चर्चा है, facterरूबी के मानक संस्करण के साथ नहीं आता है। इसलिए, लक्ष्य प्रणाली में तथ्य को प्राप्त करने के लिए किसी को स्रोत से मैन्युअल रूप से इसे स्थापित करने की आवश्यकता होती है क्योंकि तथ्य पुस्तकालय पुपेट की पूर्व-आवश्यकता है।

यह पैकेज कई प्लेटफार्मों के लिए उपलब्ध है, हालांकि इसे सुरक्षित उपयोग करने के लिए इसे स्थापित किया जा सकता है tarball, जो नवीनतम संस्करण प्राप्त करने में मदद करता है।

सबसे पहले, डाउनलोड करें tarball का उपयोग कर कठपुतली की आधिकारिक साइट से wget उपयोगिता।

$ wget http://puppetlabs.com/downloads/facter/facter-latest.tgz  ------: 1

इसके बाद, टार फाइल को अन-टार करें। सीडी कमांड का उपयोग करके अनारक्षित निर्देशिका के अंदर जाओ। अंत में, फैक्टर का उपयोग करके स्थापित करेंinstall.rb अंदर मौजूद फ़ाइल facter निर्देशिका।

$ gzip -d -c facter-latest.tgz | tar xf - -----: 2 
$ cd facter-* ------: 3 $ sudo ruby install.rb # or become root and run install.rb -----:4

स्रोत से कठपुतली स्थापित करना

सबसे पहले, कठपुतली साइट से कठपुतली टारबॉल स्थापित करें wget। फिर, टारबॉल को लक्ष्य स्थान पर निकालें। का उपयोग कर बनाई गई निर्देशिका के अंदर ले जाएँCDआदेश। का उपयोग करते हुएinstall.rb फ़ाइल, अंतर्निहित सर्वर पर कठपुतली स्थापित करें।

# get the latest tarball 
$ wget http://puppetlabs.com/downloads/puppet/puppet-latest.tgz -----: 1 # untar and install it $ gzip -d -c puppet-latest.tgz | tar xf - ----: 2 
$ cd puppet-* ------: 3 $ sudo ruby install.rb # or become root and run install.rb -------: 4

रूबी रत्न का उपयोग कठपुतली और कारक स्थापित करना

# Installing Facter 
$ wget http://puppetlabs.com/downloads/gems/facter-1.5.7.gem $ sudo gem install facter-1.5.7.gem

# Installing Puppet 
$ wget http://puppetlabs.com/downloads/gems/puppet-0.25.1.gem $ sudo gem install puppet-0.25.1.gem

एक बार जब हम सिस्टम पर कठपुतली स्थापित कर लेते हैं, तो अगला कदम यह होता है कि कुछ प्रारंभिक ऑपरेशन करने के लिए इसे कॉन्फ़िगर किया जाए।

मशीनों पर फ़ायरवॉल पोर्ट खोलें

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

विन्यास फाइल

कठपुतली के लिए मुख्य विन्यास फाइल है etc/puppet/puppet.conf। सभी विन्यास फाइल कठपुतली के संकुल-आधारित विन्यास में निर्मित होती हैं। अधिकतर विन्यास जो कठपुतली को कॉन्फ़िगर करने के लिए आवश्यक है, इन फाइलों में रखा जाता है और एक बार कठपुतली चलाने के बाद, यह स्वचालित रूप से उन विन्यास को चुनता है। हालाँकि, कुछ विशिष्ट कार्यों जैसे वेब सर्वर या बाहरी प्रमाणपत्र प्राधिकरण (CA) को कॉन्फ़िगर करने के लिए, कठपुतली में फ़ाइलों और सेटिंग्स के लिए अलग कॉन्फ़िगरेशन है।

सर्वर कॉन्फ़िगरेशन फ़ाइल में स्थित हैं conf.dनिर्देशिका जिसे कठपुतली मास्टर के रूप में भी जाना जाता है। ये फ़ाइलें डिफ़ॉल्ट रूप से स्थित हैं/etc/puppetlabs/puppetserver/conf.dपथ। ये कॉन्फिग फाइल HOCON फॉर्मेट में हैं, जो JSON की मूल संरचना को बनाए रखता है लेकिन यह अधिक पठनीय है। जब कठपुतली स्टार्टअप होता है, तो यह सभी .cong फ़ाइलों को conf.d निर्देशिका से चुनता है और किसी भी विन्यास परिवर्तन के लिए उनका उपयोग करता है। इन फ़ाइलों में कोई भी परिवर्तन सर्वर के पुनरारंभ होने पर ही होता है।

सूची फ़ाइल और सेटिंग्स फ़ाइल

  • global.conf
  • webserver.conf
  • web-routes.conf
  • puppetserver.conf
  • auth.conf
  • master.conf (पदावनत)
  • ca.conf (पदावनत)

कठपुतली में विभिन्न विन्यास फाइलें हैं जो कठपुतली में प्रत्येक घटक के लिए विशिष्ट हैं।

Puppet.conf

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

कॉन्फ़िगरेशन फ़ाइल एक मानक आईएनआई फ़ाइल जैसा दिखता है जिसमें सेटिंग्स मुख्य अनुभाग के विशिष्ट एप्लिकेशन अनुभाग में जा सकती हैं।

मुख्य विन्यास अनुभाग

[main] 
certname = Test1.vipin.com 
server = TestingSrv 
environment = production 
runinterval = 1h

कठपुतली मास्टर विन्यास फाइल

[main] 
certname = puppetmaster.vipin.com 
server = MasterSrv 
environment = production 
runinterval = 1h 
strict_variables = true  
[master] 

dns_alt_names = MasterSrv,brcleprod01.vipin.com,puppet,puppet.test.com 
reports = puppetdb 
storeconfigs_backend = puppetdb 
storeconfigs = true 
environment_timeout = unlimited

विस्तार से अवलोकन

कठपुतली विन्यास में, जिस फ़ाइल का उपयोग होने जा रहा है, उसमें कई विन्यास खंड होते हैं जिनमें प्रत्येक खंड में कई प्रकार की कई सेटिंग्स होती हैं।

विन्यास अनुभाग

कठपुतली विन्यास फाइल में मुख्य रूप से निम्नलिखित विन्यास खंड शामिल हैं।

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

  • Master - यह खंड कठपुतली मास्टर सेवा और कठपुतली प्रमाणित कमांड द्वारा संदर्भित किया जाता है।

  • Agent - इस खंड को पपेट एजेंट सेवा द्वारा संदर्भित किया जाता है।

  • User - इसका इस्तेमाल ज्यादातर कठपुतली लागू कमांड के साथ-साथ कई सामान्य कमांड द्वारा किया जाता है।

[main] 
certname = PuppetTestmaster1.example.com

विन्यास फाइल के मुख्य घटक

निम्नलिखित विन्यास फाइल के प्रमुख घटक हैं।

टिप्पणी लाइनें

कठपुतली में, किसी भी टिप्पणी लाइन के साथ शुरू होता है (#) संकेत। यह अंतरिक्ष की किसी भी राशि के साथ इरादा कर सकता है। हम एक ही पंक्ति में एक आंशिक टिप्पणी कर सकते हैं।

# This is a comment. 
Testing = true #this is also a comment in same line

सेटिंग्स लाइन्स

सेटिंग्स लाइन में शामिल होना चाहिए -

  • अग्रणी स्थान की कोई भी राशि (वैकल्पिक)
  • सेटिंग्स का नाम
  • एक बराबर = हस्ताक्षर करने के लिए, जो किसी भी स्थान से घिरा हो सकता है
  • सेटिंग के लिए एक मान

चर सेट करना

ज्यादातर मामलों में, सेटिंग्स का मूल्य एक शब्द होगा लेकिन कुछ विशेष मामलों में, कुछ विशेष मूल्य हैं।

पथ

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

# *nix version: 
environmentpath = $codedir/special_environments:$codedir/environments 
# Windows version: 
environmentpath = $codedir/environments;C:\ProgramData\PuppetLabs\code\environment

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

फ़ाइलें और निर्देशिकाएँ

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

ssldir = $vardir/ssl {owner = service, mode = 0771}

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

कठपुतली में, सभी वातावरण हैं 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.ff फ़ाइल में [मुख्य] ​​अनुभाग नहीं हो सकता है। वातावरण में सभी सेटिंग्स .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 के रूप में उपयोग करता है।

पर्यावरण का समय

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

नमूना पर्यावरण। फाइल

[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'

कठपुतली में, कठपुतली मास्टर के क्लाइंट सर्वर आर्किटेक्चर को पूरे सेटअप का नियंत्रण प्राधिकरण माना जाता है। कठपुतली मास्टर सेटअप में सर्वर के रूप में कार्य करता है और सभी नोड्स पर सभी गतिविधियों को नियंत्रित करता है।

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

आवश्यक शर्तें

Private Network DNS- फॉरवर्ड और बैकवर्ड कॉन्फ़िगर किया जाना चाहिए, जिसमें प्रत्येक सर्वर में एक अद्वितीय होस्टनाम होना चाहिए। यदि किसी के पास डीएनएस कॉन्फ़िगर नहीं है, तो कोई इंफ्रास्ट्रक्चर के साथ संचार के लिए एक निजी नेटवर्क का उपयोग कर सकता है।

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

कठपुतली मास्टर सर्वर बनाना

कठपुतली मास्टर जो हम बना रहे हैं वह मेजबान नाम के रूप में कठपुतली का उपयोग करते हुए CentOS 7 × 64 मशीन पर होने वाला है। पपेट मास्टर के निर्माण के लिए न्यूनतम सिस्टम कॉन्फ़िगरेशन दो सीपीयू कोर और 1 जीबी मेमोरी है। कॉन्फ़िगरेशन में बड़े आकार के साथ-साथ नोड्स की संख्या के आधार पर हो सकता है जो हम इस मास्टर के साथ प्रबंधित करने जा रहे हैं। बुनियादी ढांचे में, यह 2 जीबी रैम का उपयोग करके कॉन्फ़िगर किया गया है की तुलना में बड़ा है।

होस्ट का नाम भूमिका निजी FQDN
Brcleprod001 कठपुतली मास्टर bnrcleprod001.brcl.com

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

एनटीपी स्थापित कर रहा है

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

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

उपलब्ध समय क्षेत्रों की सूची बनाना

$ timedatectl list-timezones

उपरोक्त आदेश उपलब्ध समय क्षेत्रों की एक पूरी सूची प्रदान करेगा। यह समय क्षेत्र की उपलब्धता वाले क्षेत्र प्रदान करेगा।

मशीन पर आवश्यक समय क्षेत्र निर्धारित करने के लिए निम्नलिखित कमांड का उपयोग किया जा सकता है।

$ sudo timedatectl set-timezone India/Delhi

सेंटोस मशीन की yum उपयोगिता का उपयोग करके कठपुतली सर्वर मशीन पर NTP स्थापित करें।

$ sudo yum -y install ntp

एनटीपी को सिस्टम टाइम के साथ सिंक करें जो हमने उपरोक्त कमांड्स में सेट किया है।

$ sudo ntpdate pool.ntp.org

सामान्य व्यवहार में, हम सामान्य पूल का उपयोग करने के लिए NTP कॉन्फ़िगरेशन को अपडेट करेंगे जो मशीन डेटासेंटर के पास उपलब्ध है। इसके लिए, हमें ntp.conf फ़ाइल को नीचे संपादित करना होगा/etc

$ sudo vi /etc/ntp.conf

उपलब्ध NTP पूल समय क्षेत्र से समय सर्वर जोड़ें। इसके बाद ntp.conf फ़ाइल कैसी दिखती है।

brcleprod001.brcl.pool.ntp.org 
brcleprod002.brcl.pool.ntp.org 
brcleprod003.brcl.pool.ntp.org
brcleprod004.brcl.pool.ntp.org

कॉन्फ़िगरेशन सहेजें। सर्वर शुरू करें और डेमॉन को सक्षम करें।

$ sudo systemctl restart ntpd $ sudo systemctl enable ntpd

कठपुतली सर्वर सॉफ्टवेयर सेटअप

कठपुतली सर्वर सॉफ्टवेयर एक सॉफ्टवेयर है जो कठपुतली मास्टर मशीन पर चलता है। यह वह मशीन है जो पपेट एजेंट सॉफ्टवेयर चलाने वाली अन्य मशीनों के विन्यास को धक्का देती है।

निम्न आदेश का उपयोग करके आधिकारिक कठपुतली प्रयोगशाला संग्रह भंडार सक्षम करें।

$ sudo rpm -ivh https://yum.puppetlabs.com/puppetlabs-release-pc1-el7.noarch.rpm

कठपुतली पैकेज स्थापित करें।

$ sudo yum -y install puppetserver

कठपुतली सर्वर पर मेमोरी आवंटन कॉन्फ़िगर करें

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

Vi मोड पर कठपुतली सर्वर कॉन्फ़िगरेशन संपादित करें

$ sudo vi /etc/sysconfig/puppetserver  
Find the JAVA_ARGS and use the –Xms and –Xms options to set the memory allocation. 
We will allocate 3GB of space  
JAVA_ARGS="-Xms3g -Xmx3g"

एक बार हो जाने के बाद, संपादन मोड से सहेजें और बाहर निकलें।

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

$ sudo systemctl start puppetserver

अगला, हम सेटअप करेंगे ताकि कठपुतली सर्वर शुरू हो जाए जब भी मास्टर सर्वर बूट हो।

$ sudo systemctl enable puppetserver

कठपुतली .conf Master खंड

[master] 
autosign = $confdir/autosign.conf { mode = 664 } 
reports = foreman 
external_nodes = /etc/puppet/node.rb 
node_terminus = exec 
ca = true 
ssldir = /var/lib/puppet/ssl 
certname = sat6.example.com 
strict_variables = false 
manifest = 
/etc/puppet/environments/$environment/manifests/site.pp modulepath = /etc/puppet/environments/$environment/modules 
config_version =

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

Step 1 - निम्न आदेश के साथ आधिकारिक कठपुतली प्रयोगशाला संग्रह भंडार को सक्षम करें।

$ sudo rpm -ivh https://yum.puppetlabs.com/puppetlabs-release-pc1-el7.noarch.rpm

Step 2 - कठपुतली एजेंट पैकेज स्थापित करें।

$ sudo yum -y install puppet-agent

Step 3 - कठपुतली एजेंट स्थापित होने के बाद, इसे निम्न कमांड के साथ सक्षम करें।

$ sudo /opt/puppetlabs/bin/puppet resource service puppet ensure=running enable = true

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

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

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

सूची वर्तमान प्रमाणपत्र अनुरोध

पपेट मास्टर पर, सभी अहस्ताक्षरित प्रमाणपत्र अनुरोधों को देखने के लिए निम्न आदेश चलाएँ।

$ sudo /opt/puppetlabs/bin/puppet cert list

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

"Brcleprod004.brcl.com" (SHA259) 
15:90:C2:FB:ED:69:A4:F7:B1:87:0B:BF:F7:ll:
B5:1C:33:F7:76:67:F3:F6:45:AE:07:4B:F 6:E3:ss:04:11:8d

इसमें शुरुआत में कोई + (संकेत) शामिल नहीं है, जो इंगित करता है कि प्रमाणपत्र अभी भी हस्ताक्षरित नहीं है।

एक अनुरोध पर हस्ताक्षर करें

नए सर्टिफिकेट अनुरोध पर हस्ताक्षर करने के लिए जो पपेट एजेंट रन नए नोड पर होने पर उत्पन्न हुआ था, पपेट सर्टिफिकेट साइन कमांड का उपयोग प्रमाणपत्र के होस्ट नाम के साथ किया जाएगा, जिसे नए कॉन्फ़िगर किए गए नोड द्वारा तैयार किया गया था, जिसकी जरूरत है हस्ताक्षर कराने के लिए। जैसा कि हमारे पास Brcleprod004.brcl.com का प्रमाण पत्र है, हम निम्नलिखित कमांड का उपयोग करेंगे।

$ sudo /opt/puppetlabs/bin/puppet cert sign Brcleprod004.brcl.com

निम्नलिखित होगा output

Notice: Signed certificate request for Brcle004.brcl.com 
Notice: Removing file Puppet::SSL::CertificateRequest Brcle004.brcl.com at 
'/etc/puppetlabs/puppet/ssl/ca/requests/Brcle004.brcl.com.pem'

कठपुतली विच्छेद अब नोड से संवाद कर सकता है, जहां साइन प्रमाण पत्र है।

$ sudo /opt/puppetlabs/bin/puppet cert sign --all

होस्ट को कठपुतली सेटअप से रद्द करना

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

$ sudo /opt/puppetlabs/bin/puppet cert clean hostname

सभी हस्ताक्षरित अनुरोधों को देखना

निम्न आदेश + (हस्ताक्षर) के साथ हस्ताक्षरित प्रमाणपत्रों की एक सूची उत्पन्न करेगा जो इंगित करता है कि अनुरोध स्वीकृत है।

$ sudo /opt/puppetlabs/bin/puppet cert list --all

इसके बाद होगा output

+ "puppet" (SHA256) 5A:71:E6:06:D8:0F:44:4D:70:F0:
BE:51:72:15:97:68:D9:67:16:41:B0:38:9A:F2:B2:6C:B 
B:33:7E:0F:D4:53 (alt names: "DNS:puppet", "DNS:Brcle004.nyc3.example.com")  

+ "Brcle004.brcl.com" (SHA259) F5:DC:68:24:63:E6:F1:9E:C5:FE:F5:
1A:90:93:DF:19:F2:28:8B:D7:BD:D2:6A:83:07:BA:F E:24:11:24:54:6A 

+ " Brcle004.brcl.com" (SHA259) CB:CB:CA:48:E0:DF:06:6A:7D:75:E6:CB:22:BE:35:5A:9A:B3

एक बार ऊपर हो जाने के बाद, हमारे पास अपना बुनियादी ढांचा तैयार है जिसमें कठपुतली मास्टर अब नए जोड़े गए नोड्स को प्रबंधित करने में सक्षम है।

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

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

$ urlgrabber -o /etc/yum.repos.d/timhughes-r10k-epel-6.repo
https://copr.fedoraproject.org/coprs/timhughes/yum -y install rubygem-r10k

/Etc/puppet/puppet.conf में पर्यावरण कॉन्फ़िगर करें

[main] 
environmentpath = $confdir/environments

R10k विन्यास के लिए एक विन्यास फाइल बनाएँ

cat <<EOF >/etc/r10k.yaml 
# The location to use for storing cached Git repos 
:cachedir: '/var/cache/r10k' 
# A list of git repositories to create 
:sources: 
# This will clone the git repository and instantiate an environment per 
# branch in /etc/puppet/environments 
:opstree: 
#remote: 'https://github.com/fullstack-puppet/fullstackpuppet-environment.git' 
remote: '/var/lib/git/fullstackpuppet-environment.git' 
basedir: '/etc/puppet/environments' 
EOF

कठपुतली मैनिफेस्ट और मॉड्यूल स्थापित करना

r10k deploy environment -pv

जैसा कि हमें हर 15 मिनट में पर्यावरण को अपडेट करने की आवश्यकता है, हम उसी के लिए क्रॉन जॉब बनाएंगे।

cat << EOF > /etc/cron.d/r10k.conf 
SHELL = /bin/bash 
PATH = /sbin:/bin:/usr/sbin:/usr/bin 
H/15 * * * * root r10k deploy environment -p 
EOF

परीक्षण स्थापना

यदि सब कुछ स्वीकार किए जाते हैं, तो परीक्षण करने के लिए, किसी को कठपुतली मॉड्यूल के कठपुतली प्रकट को संकलित करने की आवश्यकता है। निम्न आदेश चलाएँ और परिणाम के रूप में एक YAML आउटपुट प्राप्त करें।

curl --cert /etc/puppet/ssl/certs/puppet.corp.guest.pem \ 
--key /etc/puppet/ssl/private_keys/puppet.corp.guest.pem \ 
--cacert /etc/puppet/ssl/ca/ca_crt.pem \ 
-H 'Accept: yaml' \ 
https://puppet.corp.guest:8140/production/catalog/puppet.corp.guest

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

वर्चुअल मशीन की स्थापना

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

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

निर्देशिका संरचना

- manifests 
   \- site.pp 
- modules 
   \- your modules  
- test 
   \- update-puppet.sh 
   \- Vagrantfile 
- puppet.conf

वैग्रांत फ़ाइल

# -*- mode: ruby -*- 
# vi: set ft = ruby : 
Vagrant.configure("2") do |config| 
   config.vm.box = "precise32" 
   config.vm.box_url = "http://files.vagrantup.com/precise64.box" 
   config.vm.provider :virtualbox do |vb| 
      vb.customize ["modifyvm", :id, "--memory", 1028, "--cpus", 2] 
   end 
  
   # Mount our repo onto /etc/puppet 
   config.vm.synced_folder "../", "/etc/puppet"  
   
   # Run our Puppet shell script   
   config.vm.provision "shell" do |s| 
      s.path = "update-puppet.sh" 
   end  
 
   config.vm.hostname = "localdev.example.com" 
end

उपर्युक्त कोड में, हमने शेल प्रस्तोता का उपयोग किया है जिसमें हम एक शेल स्क्रिप्ट नाम चलाने की कोशिश कर रहे हैं update-puppet.sh। स्क्रिप्ट उसी निर्देशिका में मौजूद होती है, जहाँ Vagrant फ़ाइल स्थित होती है और स्क्रिप्ट की सामग्री नीचे सूचीबद्ध होती है।

!/bin/bash 
echo "Puppet version is $(puppet --version)" if [ $( puppet --version) != "3.4.1" ]; then  
   echo "Updating puppet" 
   apt-get install --yes lsb-release 
   DISTRIB_CODENAME = $(lsb_release --codename --short) DEB = "puppetlabs-release-${DISTRIB_CODENAME}.deb" 
   DEB_PROVIDES="/etc/apt/sources.list.d/puppetlabs.list"  
   
   if [ ! -e $DEB_PROVIDES ] then wget -q http://apt.puppetlabs.com/$DEB 
      sudo dpkg -i $DEB 
   fi  
sudo apt-get update 
   sudo apt-get install -o Dpkg::Options:: = "--force-confold" 
   --force-yes -y puppet 
else 
   echo "Puppet is up to date!" 
fi

आगे की प्रक्रिया, उपयोगकर्ता को नाम के साथ मैनिफ़ेस्ट निर्देशिका के अंदर एक मैनिफ़ेस्ट फ़ाइल बनाने की आवश्यकता है site.pp जो VM पर कुछ सॉफ़्टवेयर स्थापित करेगा।

node 'brclelocal03.brcl.com' { 
   package { ['vim','git'] : 
      ensure => latest 
   } 
} 
echo "Running puppet" 
sudo puppet apply /etc/puppet/manifests/site.pp

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

निम्नलिखित उत्पादन होगा।

Notice: Compiled catalog for localdev.example.com in environment production in 0.09 seconds 
Notice: /Stage[main]/Main/Node[brclelocal03.brcl.com]/Package[git]/ensure: created 
Notice: /Stage[main]/Main/Node[brcllocal03.brcl.com]/Package[vim]/ensure: ensure changed 'purged' to 'latest'

एकाधिक मशीन कॉन्फ़िगरेशन को मान्य करना

अगर हमें स्थानीय स्तर पर कई मशीनों के कॉन्फ़िगरेशन का परीक्षण करने की आवश्यकता है, तो इसे केवल वैग्रांट कॉन्फ़िगरेशन फ़ाइल में परिवर्तन करके किया जा सकता है।

नई संरचित वैग्रांत फ़ाइल

config.vm.define "brclelocal003" do |brclelocal003| 
   brclelocal03.vm.hostname = "brclelocal003.brcl.com" 
end  

config.vm.define "production" do |production| 
   production.vm.hostname = "brcleprod004.brcl.com" 
end

मान लें कि हमारे पास एक नया उत्पादन सर्वर है, जिसे एसएसएल उपयोगिता स्थापित करने की आवश्यकता है। हमें निम्नलिखित कॉन्फ़िगरेशन के साथ पुराने प्रकट को विस्तारित करने की आवश्यकता है।

node 'brcleprod004.brcl.com' inherits 'brcleloacl003.brcl.com' { 
   package { ['SSL'] : 
      ensure => latest 
   } 
}

मैनिफ़ेस्ट फ़ाइल में कॉन्फ़िगरेशन परिवर्तन करने के बाद, हमें केवल परीक्षण निर्देशिका में जाने और मूल आव्रजक कमांड चलाने की आवश्यकता है जो दोनों को लाएगा brclelocal003.brcl.com तथा brcleprod004.brcl.comमशीन। हमारे मामले में, हम उत्पादन मशीन लाने की कोशिश कर रहे हैं जिसे चलाकर किया जा सकता हैvagrant up production command। वोग्रांट फाइल में परिभाषित नाम उत्पादन के साथ एक नई मशीन बनाएगा और इसमें एसएसएल पैकेज स्थापित होगा।

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

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

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

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

साधन

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

कठपुतली में, सभी संसाधनों को एक साथ उपयोग करके एकत्र किया जाता है “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, 
}

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

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

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; 
   } 
}

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

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

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' }

यहां ध्यान देने योग्य महत्वपूर्ण बात यह है कि एक परिभाषा के साथ एक चर का उपयोग कैसे किया जा सकता है। हम प्रयोग करते हैं ($) डॉलर संकेत चर। उपरोक्त में, हमने उपयोग किया है$title. Definitions can have both a $शीर्षक और $name with which the name and the title can be represented. By default, $शीर्षक और $name are set to the same value, but one can set a title attribute and pass different name as a parameter. $शीर्षक और $ नाम केवल परिभाषा में काम करता है, वर्ग या अन्य संसाधन में नहीं।

मॉड्यूल

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

नोड्स

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

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

नोड नाम एक छोटा होस्ट नाम या पूरी तरह से योग्य डोमेन नाम (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, 
}

Puppet 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']  
}

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

कठपुतली का मूल तरीका है, जिस तरह से संसाधनों को घोषित किया जाता है और कैसे ये संसाधन उनके राज्य का प्रतिनिधित्व कर रहे हैं। किसी भी प्रकट में, उपयोगकर्ता के पास विभिन्न प्रकार के संसाधनों का एक संग्रह हो सकता है जो वर्ग और परिभाषा का उपयोग करके एक साथ समूहीकृत होते हैं।

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

मैनिफेस्ट फ़ाइल वर्कफ़्लो

कठपुतली प्रकट में निम्नलिखित घटक होते हैं -

  • Files (ये प्लेन फाइलें हैं जहां कठपुतली का उनसे कोई लेना-देना नहीं है, बस उन्हें उठाकर लक्ष्य स्थान पर रखना है)

  • Resources

  • Templates (इनका उपयोग नोड पर कॉन्फ़िगरेशन फ़ाइलों के निर्माण के लिए किया जा सकता है)।

  • Nodes (क्लाइंट नोड से संबंधित सभी परिभाषा यहां परिभाषित की गई है)

  • Classes

नोट करने के लिए अंक

  • कठपुतली में, सभी प्रकट फाइलें रूबी को उनकी एन्कोडिंग भाषा के रूप में उपयोग करती हैं और उनके साथ बच जाती हैं .pp विस्तार।

  • कठपुतली शुरू होने पर फ़ाइलों को लोड करने के लिए कई अभिव्यक्तियों में "आयात" कथन का उपयोग किया जाता है।

  • निर्देशिका में निहित सभी फ़ाइलों को आयात करने के लिए, आप आयात कथन का उपयोग किसी अन्य तरीके से कर सकते हैं जैसे कि 'क्लाइंट / *'। यह सब आयात करेगा.pp उस निर्देशिका के अंदर फाइलें।

मैनिफ़ेस्ट लिखना

चर के साथ काम करना

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

स्ट्रिंग चर उदाहरण

$package = "vim" package { $package: 
   ensure => "installed" 
}

लूप्स का उपयोग करना

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

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

$packages = ['vim', 'git', 'curl'] package { $packages: 
   ensure => "installed" 
}

सशर्त का उपयोग करना

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

if $OperatingSystem != 'Linux' { 
   warning('This manifest is not supported on this other OS apart from linux.') 
} else { 
   notify { 'the OS is Linux. We are good to go!': }
}

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

मॉड्यूल विन्यास

किसी भी कठपुतली मॉड्यूल में, हमारे पास दो विभाजन हैं जो कोड की संरचना को परिभाषित करने और हर को नियंत्रित करने में मदद करते हैं।

  • मॉड्यूल की खोज पथ को बृहदान्त्र-अलग-अलग निर्देशिकाओं की सूची का उपयोग करके कॉन्फ़िगर किया गया है puppetmasterd या masterdपपेट के मास्टर कॉन्फ़िगरेशन फ़ाइल के बाद के भाग के साथ modulepath पैरामीटर।

[puppetmasterd] 
... 
modulepath = /var/lib/puppet/modules:/data/puppet/modules

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

  • Fileserver.conf में फ़ाइल सर्वर मॉड्यूल के लिए एक्सेस कंट्रोल सेटिंग्स, उस मॉड्यूल के लिए पथ कॉन्फ़िगरेशन को हमेशा अनदेखा किया जाता है, और एक पथ निर्दिष्ट करने से एक चेतावनी उत्पन्न होगी।

मॉड्यूल स्रोत

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

एक उचित डिफ़ॉल्ट पथ के रूप में कॉन्फ़िगर किया जा सकता है -

/etc/puppet/modules:/usr/share/puppet:/var/lib/modules.

वैकल्पिक रूप से, / etc / कठपुतली निर्देशिका को एक विशेष अनाम मॉड्यूल के रूप में स्थापित किया जा सकता है, जिसे हमेशा पहले खोजा जाता है।

मॉड्यूल नामकरण

कठपुतली एक विशेष मॉड्यूल के समान नामकरण मानकों का पालन करती है जिसमें मॉड्यूल का नाम सामान्य शब्द होना चाहिए, [- \\ w +] (अक्षर, शब्द, संख्या, अंडरस्कोर और डैश) से मेल खाते हुए और नाम स्थान विभाजक से युक्त नहीं:: / /। हालांकि इसे मॉड्यूल पदानुक्रम के बारे में अनुमति दी जा सकती है, नए मॉड्यूल के लिए इसे नेस्टेड नहीं किया जा सकता है।

मॉड्यूल आंतरिक संगठन

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

MODULE_PATH/ 
   downcased_module_name/ 
      files/ 
      manifests/ 
         init.pp 
      lib/ 
         puppet/ 
            parser/ 
               functions 
            provider/ 
            type/ 
         facter/ 
      templates/ 
      README

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

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

उदाहरण

एक ऑटोफॉल्स मॉड्यूल पर विचार करें जो एक निश्चित ऑटो.होम मैप स्थापित करता है और टेम्पलेट्स से ऑटो.मास्टर उत्पन्न करता है।

class autofs { 
   package { autofs: ensure => latest } 
   service { autofs: ensure => running } 
   
   file { "/etc/auto.homes": 
      source => "puppet://$servername/modules/autofs/auto.homes" 
   } 
   file { "/etc/auto.master": 
      content => template("autofs/auto.master.erb") 
   } 
}

फ़ाइल सिस्टम में निम्न फ़ाइलें होंगी।

MODULE_PATH/ 
autofs/ 
manifests/ 
init.pp 
files/ 
auto.homes 
templates/ 
auto.master.erb

मॉड्यूल लुकअप

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

फाइलरवर पर फ़ाइल संदर्भों के लिए, इसी तरह के संदर्भ का उपयोग किया जाता है ताकि कठपुतली का एक संदर्भ: //$servername/modules/autofs/auto.homes फ़ाइल के ऑटोफ़ॉक्स / फ़ाइल / ऑटो.होम्स को मॉड्यूल के पथ में हल करता है।

कमांड लाइन क्लाइंट और कठपुतली मास्टर दोनों के साथ मॉड्यूल को उपयोग करने योग्य बनाने के लिए, कोई कठपुतली के URL का उपयोग कर सकता है: /// पथ। यानी एक स्पष्ट सर्वर नाम के बिना एक URL। इस तरह के URL से थोड़ा अलग व्यवहार किया जाता हैPuppet तथा puppetd। कठपुतली स्थानीय फाइल सिस्टम में सर्वर रहित URL की खोज करती है।

टेम्प्लेट फ़ाइलों को प्रकट और फ़ाइलों के समान तरीके से खोजा जाता है: टेम्प्लेट का एक उल्लेख ("ऑटोफ़्स / ऑटो.मास्टरबीबी") कठपुतली को पहले एक फ़ाइल में देखने के लिए बना देगा $templatedir/autofs/auto.master.erb और फिर autofs/templates/auto.master.erbमॉड्यूल पथ पर। कठपुतली के तहत सब कुछ के कठपुतली संस्करणों के साथ, यह उपयोग करने के लिए उपलब्ध है। इसे मॉड्यूल ऑटो लोडिंग कहा जाता है। कठपुतली मॉड्यूल से ऑटो-लोड कक्षाओं और परिभाषाओं का प्रयास करेगी।

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

class { 'java':  
   package               => 'jdk-8u25-linux-x64',  
   java_alternative      => 'jdk1.8.0_25',  
   java_alternative_path => '/usr/java/jdk1.8.0_25/jre/bin/java'  
}

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

“puppet://server/modules/module_name/sudoers”

फाइल प्रारूप

कठपुतली निर्देशिका संरचना में, डिफ़ॉल्ट रूप से फ़ाइल सर्वर कॉन्फ़िगरेशन के तहत स्थित है /etc/puppet/fileserver.config निर्देशिका, यदि उपयोगकर्ता इस डिफ़ॉल्ट कॉन्फ़िगरेशन फ़ाइल पथ को बदलना चाहता है, तो इसे नए कॉन्फ़िगरेशन ध्वज का उपयोग करके किया जा सकता है puppetmasterd। कॉन्फ़िगरेशन फ़ाइल INI फ़ाइलों जैसा दिखता है, लेकिन वास्तव में समान नहीं है।

[module] 
path /path/to/files 
allow *.domain.com 
deny *.wireless.domain.com

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

पथ में कोई भी या सभी% d,% h और% H हो सकते हैं जो गतिशील रूप से इसके डोमेन नाम, इसके होस्ट नाम और पूरी तरह से योग्य होस्ट नाम से प्रतिस्थापित किए जाते हैं। सभी को क्लाइंट के एसएसएल सर्टिफिकेट से लिया जाता है (इसलिए होस्टनाम और सर्टिफिकेट के नाम में बेमेल होने पर सावधान रहें)। यह उपयोगी है मॉड्यूल बना रहा है जहां प्रत्येक क्लाइंट की फ़ाइलों को पूरी तरह से अलग रखा गया है। उदाहरण, निजी होस्ट कुंजी के लिए।

[private] 
path /data/private/%h 
allow *

उपरोक्त कोड स्निपेट में, कोड क्लाइंट से फ़ाइल / pStreet/file.txt की खोज करने की कोशिश कर रहा है client1.vipin.com। यह /data/pStreet/client1/file.txt में इसके लिए दिखेगा, जबकि client2.vipin.com के लिए समान अनुरोध फ़ाइल सर्वर पर /data/pStreet/client2/file.txt फ़ाइल को पुनर्प्राप्त करने का प्रयास करेगा।

सुरक्षा

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

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

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

होस्ट का नाम

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

[export] 
path /usr 
allow brcleprod001.brcl.com 
allow *.brcl.com 
deny brcleprod002.brcl.com

आईपी ​​पता

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

[export] 
path /usr 
allow 127.0.0.1 
allow 172.223.30.* 
allow 172.223.30.0/24

वैश्विक अनुमति

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

[export] 
path /export 
allow *

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

# facter

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

यदि कोई केवल एक चर देखना चाहता है। यह निम्नलिखित कमांड का उपयोग करके किया जा सकता है।

# facter {Variable Name}  

Example 
[root@puppetmaster ~]# facter virtual 
virtualbox

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

टेस्ट के लिए उदाहरण

[root@puppetmaster modules]# tree brcle_account 
brcle_account 
└── manifests  └── init.pp [root@puppetmaster modules]# cat brcle_account/manifests/init.pp  
class brcle_account {  
   user { 'G01063908': 
      ensure => 'present', 
      uid => '121', 
      shell => '/bin/bash', 
      home => '/home/G01063908', 
   }  
   
   file {'/tmp/userfile.txt': 
      ensure => file, 
      content => "the value for the 'OperatingSystem' fact is: $OperatingSystem \n", 
   } 
}

यह परीक्षण

[root@puppetmaster modules]# puppet agent --test 
Notice: /Stage[main]/Activemq::Service/Service[activemq]/ensure: 
ensure changed 'stopped' to 'running' 
Info: /Stage[main]/Activemq::Service/Service[activemq]: 
Unscheduling refresh on Service[activemq] 

Notice: Finished catalog run in 4.09 seconds  
[root@puppetmaster modules]# cat /tmp/testfile.txt  
the value for the 'OperatingSystem' fact is: Linux   

[root@puppetmaster modules]# facter OperatingSystem 
Linux

जैसा कि हम उपरोक्त कोड स्निपेट में देख सकते हैं, हमने परिभाषित नहीं किया है OperatingSystem। हमने बस मूल्य को नरम कोडित मूल्य से बदल दिया है$OperatingSystem सामान्य चर के रूप में।

कठपुतली में, तीन प्रकार के तथ्य हैं जिनका उपयोग और परिभाषित किया जा सकता है -

  • मुख्य तथ्य
  • कस्टम तथ्य
  • बाहरी तथ्य

कोर तथ्यों को शीर्ष स्तर पर परिभाषित किया गया है और कोड में किसी भी बिंदु पर सभी के लिए सुलभ है।

कठपुतली तथ्य

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

[root@puppetagent1 ~]# facter
architecture => x86_64 
augeasversion => 1.0.0 
bios_release_date => 13/09/2012 
bios_vendor => innotek GmbH 
bios_version => VirtualBox 
blockdevice_sda_model => VBOX HARDDISK 
blockdevice_sda_size => 22020587520 
blockdevice_sda_vendor => ATA 
blockdevice_sr0_model => CD-ROM 
blockdevice_sr0_size => 1073741312 
blockdevice_sr0_vendor => VBOX 
blockdevices => sda,sr0 
boardmanufacturer => Oracle Corporation 
boardproductname => VirtualBox 
boardserialnumber => 0 

domain => codingbee.dyndns.org  
facterversion => 2.1.0 
filesystems => ext4,iso9660 
fqdn => puppetagent1.codingbee.dyndns.org 
hardwareisa => x86_64 
hardwaremodel => x86_64 
hostname => puppetagent1 
id => root 
interfaces => eth0,lo 
ipaddress => 172.228.24.01 
ipaddress_eth0 => 172.228.24.01 
ipaddress_lo => 127.0.0.1 
is_virtual => true 
kernel => Linux 
kernelmajversion => 2.6 
kernelrelease => 2.6.32-431.23.3.el6.x86_64 
kernelversion => 2.6.32 
lsbdistcodename => Final 
lsbdistdescription => CentOS release 6.5 (Final) 
lsbdistid => CentOS 
lsbdistrelease => 6.5 
lsbmajdistrelease => 6 
lsbrelease => :base-4.0-amd64:base-4.0-noarch:core-4.0-amd64:core-4.0noarch:graphics-4.0-amd64:
graphics-4.0-noarch:printing-4.0-amd64:printing-4.0noarch 
macaddress => 05:00:22:47:H9:77 
macaddress_eth0 => 05:00:22:47:H9:77 
manufacturer => innotek GmbH 
memoryfree => 125.86 GB 
memoryfree_mb => 805.86 
memorysize => 500 GB 
memorysize_mb => 996.14 
mtu_eth0 => 1500 
mtu_lo => 16436 
netmask => 255.255.255.0 
netmask_eth0 => 255.255.255.0  

network_lo => 127.0.0.0 
operatingsystem => CentOS 
operatingsystemmajrelease => 6 
operatingsystemrelease => 6.5 
osfamily => RedHat 
partitions => {"sda1"=>{
"uuid"=>"d74a4fa8-0883-4873-8db0-b09d91e2ee8d", "size" =>"1024000", 
"mount" => "/boot", "filesystem" => "ext4"}, "sda2"=>{"size" => "41981952", 
"filesystem" => "LVM2_member"}
} 
path => /usr/lib64/qt3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin 
physicalprocessorcount => 1 
processor0 => Intel(R) Core(TM) i7 CPU         920  @ 2.67GHz 
processor1 => Intel(R) Core(TM) i7 CPU         920  @ 2.67GHz 
processor2 => Intel(R) Core(TM) i7 CPU         920  @ 2.67GHz 
processorcount => 3 
productname => VirtualBox 
ps => ps -ef 
puppetversion => 3.6.2 
rubysitedir => /usr/lib/ruby/site_ruby/1.8 
rubyversion => 1.8.7
selinux => true 
selinux_config_mode => enforcing 
selinux_config_policy => targeted 
selinux_current_mode => enforcing 
selinux_enforced => true 
selinux_policyversion => 24 
serialnumber => 0 
sshdsakey => AAAAB3NzaC1kc3MAAACBAK5fYwRM3UtOs8zBCtRTjuHLw56p94X/E0UZBZwFR3q7
WH0x5+MNsjfmdCxKvpY/WlIIUcFJzvlfjXm4qDaTYalbzSZJMT266njNbw5WwLJcJ74KdW92ds76pjgm
CsjAh+R9YnyKCEE35GsYjGH7whw0gl/rZVrjvWYKQDOmJA2dAAAAFQCoYABgjpv3EkTWgjLIMnxA0Gfud
QAAAIBM4U6/nerfn6Qvt43FC2iybvwVo8ufixJl5YSEhs92uzsW6jiw68aaZ32q095/gEqYzeF7a2knr
OpASgO9xXqStYKg8ExWQVaVGFTR1NwqhZvz0oRSbrN3h3tHgknoKETRAg/imZQ2P6tppAoQZ8wpuLrXU
CyhgJGZ04Phv8hinAAAAIBN4xaycuK0mdH/YdcgcLiSn8cjgtiETVzDYa+jF 
swapfree => 3.55 GB 
swapfree_mb => 2015.99 
swapsize => 3.55 GB 
swapsize_mb => 2015.99 
timezone => GMT 
type => Other 
uniqueid => a8c0af01 
uptime => 45:012 hours 
uptime_days => 0 
uptime_hours => 6 
uptime_seconds => 21865 
uuid => BD8B9D85-1BFD-4015-A633-BF71D9A6A741 
virtual => virtualbox

उपरोक्त कोड में, हम कुछ डेटा ओवरलैप को bash "env" वैरिएबल में उपलब्ध कुछ जानकारी के साथ देख सकते हैं। पपेट सीधे डेटा का उपयोग नहीं करता है, इसके बजाय यह फैक्टर डेटा का उपयोग करता है, फैक्टर डेटा को वैश्विक चर के रूप में माना जाता है।

तथ्य तब शीर्ष स्तर चर के रूप में उपलब्ध हैं और कठपुतली मास्टर अनुरोध एजेंट के लिए कठपुतली सूची को संकलित करने के लिए उनका उपयोग कर सकते हैं। $ उपसर्ग के साथ कारकों को सामान्य चर के रूप में प्रकट किया जाता है।

उदाहरण

if ($OperatingSystem == "Linux") { 
   $message = "This machine OS is of the type $OperatingSystem \n" 
} else { 
   $message = "This machine is unknown \n" } file { "/tmp/machineOperatingSystem.txt": ensure => file, content => "$message" 
}

उपरोक्त मेनिफ़ेस्ट फ़ाइल केवल एक एकल फ़ाइल के बारे में परेशान करती है जिसे कहा जाता है machineOperatingSystem.txt, जहां इस फ़ाइल की सामग्री को इस तथ्य से कटौती की जाती है OperatingSystem

[root@puppetagent1 /]# facter OperatingSystem 
Linux  

[root@puppetagent1 /]# puppet apply /tmp/ostype.pp 
Notice: Compiled catalog for puppetagent1.codingbee.dyndns.org 
in environment production in 0.07 seconds 
Notice: /Stage[main]/Main/File[/tmp/machineOperatingSystem.txt]/ensure: 
defined content as '{md5}f59dc5797d5402b1122c28c6da54d073' 
Notice: Finished catalog run in 0.04 seconds  

[root@puppetagent1 /]# cat /tmp/machinetype.txt 
This machine OS is of the type Linux

कस्टम तथ्य

उपरोक्त सभी तथ्य जो हमने देखे हैं वे मशीन के मुख्य तथ्य हैं। निम्नांकित तरीकों से इस कस्टम तथ्य को नोड में जोड़ा जा सकता है -

  • "निर्यात फैक्टर ... सिंटैक्स" का उपयोग करना
  • $ LOAD_PATH सेटिंग का उपयोग करना
  • FACTERLIB
  • Pluginsync

"निर्यात फैक्टर" सिंटैक्स का उपयोग करना

निर्यात FACTER_ {तथ्य का नाम} वाक्य रचना का उपयोग करके तथ्यों को मैन्युअल रूप से जोड़ सकते हैं।

उदाहरण

[root@puppetagent1 facter]# export FACTER_tallest_mountain="Everest" 
[root@puppetagent1 facter]# facter tallest_mountain Everest

$ LOAD_PATH सेटिंग का उपयोग करना

रूबी में, $LOAD_PATH is equivalent to Bash special parameter. Although it is similar to bash $पैठ चर, वास्तविक तथ्यों में $ LOAD_PATH एक पर्यावरण चर नहीं है, इसके बजाय यह एक पूर्व-परिभाषित चर है।

$ LOAD_PATH का पर्यायवाची "$:" है। यह चर मानों को खोजने और लोड करने के लिए एक सरणी है।

[root@puppetagent1 ~]# ruby -e 'puts $LOAD_PATH'            
# note you have to use single quotes.  
/usr/lib/ruby/site_ruby/1.6 
/usr/lib64/ruby/site_ruby/1.6 
/usr/lib64/ruby/site_ruby/1.6/x86_64-linux 
/usr/lib/ruby/site_ruby 
/usr/lib64/ruby/site_ruby 
/usr/lib64/site_ruby/1.6 
/usr/lib64/site_ruby/1.6/x86_64-linux 
/usr/lib64/site_ruby 
/usr/lib/ruby/1.6 
/usr/lib64/ruby/1.6 
/usr/lib64/ruby/1.6/x86_64-linux

चलो एक निर्देशिका फैक्टर बनाने और एक ऐड जोड़ने का एक उदाहरण लेते हैं .pp फ़ाइल और उसमें सामग्री जोड़ना।

[root@puppetagent1 ~]# cd /usr/lib/ruby/site_ruby/ 
[root@puppetagent1 site_ruby]# mkdir facter 
[root@puppetagent1 site_ruby]# cd facter/ 
[root@puppetagent1 facter]# ls 
[root@puppetagent1 facter]# touch newadded_facts.rb

निम्न सामग्री को custom_facts.rb फ़ाइल में जोड़ें।

[root@puppetagent1 facter]# cat newadded_facts.rb 
Facter.add('tallest_mountain') do 
   setcode "echo Everest" 
end

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

FACTERLIB का उपयोग करना

कठपुतली में, FACTERLIB बहुत अधिक $ LOAD_PATH के समान काम करता है, लेकिन केवल एक महत्वपूर्ण अंतर के साथ, यह एक रूबी विशेष चर के बजाय एक OS स्तर पर्यावरण पैरामीटर है। डिफ़ॉल्ट रूप से, पर्यावरण चर सेट नहीं किया जा सकता है।

[root@puppetagent1 facter]# env | grep "FACTERLIB" 
[root@puppetagent1 facter]#

FACTERLIB का परीक्षण करने के लिए, हमें निम्नलिखित चरणों का पालन करना होगा।

निम्नलिखित संरचना में test_facts नामक एक फ़ोल्डर बनाएँ।

[root@puppetagent1 tmp]# tree /tmp/test_facts/ 
/tmp/some_facts/ 
├── vipin 
│   └── longest_river.rb 
└── testing 
   └── longest_wall.rb

.Rb फ़ाइलों के लिए निम्न सामग्री जोड़ें।

[root@puppetagent1 vipin]# cat longest_river.rb 
Facter.add('longest_river') do 
   setcode "echo Nile" 
end 

[root@puppetagent1 testing]# cat longest_wall.rb 
Facter.add('longest_wall') do 
   setcode "echo 'China Wall'" 
end

निर्यात विवरण का उपयोग करें।

[root@puppetagent1 /]# export 
FACTERLIB = "/tmp/some_facts/river:/tmp/some_facts/wall" 
[root@puppetagent1 /]# env | grep "FACTERLIB" 
FACTERLIB = /tmp/some_facts/river:/tmp/some_facts/wall

नए तथ्य का परीक्षण करें।

[root@puppetagent1 /]# facter longest_river 
Nile 
[root@puppetagent1 /]# facter longest_wall 
China Wall

बाहरी तथ्य

बाहरी तथ्य बहुत उपयोगी होते हैं जब उपयोगकर्ता प्रावधान समय पर बनाए गए कुछ नए तथ्यों को लागू करना चाहता है। बाहरी तथ्य मेटाडेटा को वीएम पर लागू करने के महत्वपूर्ण तरीकों में से एक है इसके प्रावधान चरण (जैसे vSphere, OpenStack, AWS, आदि का उपयोग करके)

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

एक बाहरी तथ्य बनाना

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

$ mkdir -p /etc/facter/facts.d

निम्न सामग्री के साथ निर्देशिका में शेल स्क्रिप्ट बनाएँ।

$ ls -l /etc/facter/facts.d 
total 4 
-rwxrwxrwx. 1 root root 65 Sep 18 13:11 external-factstest.sh 
$ cat /etc/facter/facts.d/external-factstest.sh 
#!/bin/bash 
echo "hostgroup = dev" 
echo "environment = development"

स्क्रिप्ट फ़ाइल की अनुमति बदलें।

$ chmod u+x /etc/facter/facts.d/external-facts.sh

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

$ facter hostgroup dev $ facter environment 
development

पपेट में कस्टम तथ्य लिख सकते हैं। एक संदर्भ के रूप में, कठपुतली साइट से निम्न लिंक का उपयोग करें।

https://docs.puppet.com/facter/latest/fact_overview.html#writing-structured-facts

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

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

user { 'vipin': 
   ensure => present, 
   uid    => '552', 
   shell  => '/bin/bash', 
   home   => '/home/vipin', 
}

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

  • Resource Type - उपरोक्त कोड स्निपेट में, यह उपयोगकर्ता है।

  • Resource Parameter - उपरोक्त कोड स्निपेट में, यह विपिन है।

  • Attributes - उपरोक्त कोड स्निपेट में, यह सुनिश्चित है, यूआईडी, शेल, होम।

  • Values - ये ऐसे मूल्य हैं जो प्रत्येक संपत्ति के अनुरूप हैं।

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

संसाधन प्रकार

पपेट में विभिन्न प्रकार के संसाधन उपलब्ध हैं जिनकी कार्यक्षमता का अपना तरीका है। इन संसाधन प्रकारों को "-लिस्ट" विकल्प के साथ "वर्णन" कमांड का उपयोग करके देखा जा सकता है।

[root@puppetmaster ~]# puppet describe --list 
These are the types known to puppet: 
augeas          - Apply a change or an array of changes to the  ... 
computer        - Computer object management using DirectorySer ... 
cron            - Installs and manages cron jobs 
exec            - Executes external commands 
file            - Manages files, including their content, owner ... 
filebucket      - A repository for storing and retrieving file  ... 
group           - Manage groups 
host            - Installs and manages host entries 
interface       - This represents a router or switch interface 
k5login         - Manage the ‘.k5login’ file for a user 
macauthorization - Manage the Mac OS X authorization database 
mailalias       - .. no documentation .. 
maillist        - Manage email lists 
mcx             - MCX object management using DirectoryService  ... 
mount           - Manages mounted filesystems, including puttin ... 
nagios_command  - The Nagios type command 
nagios_contact  - The Nagios type contact 
nagios_contactgroup - The Nagios type contactgroup 
nagios_host     - The Nagios type host 
nagios_hostdependency - The Nagios type hostdependency 
nagios_hostescalation - The Nagios type hostescalation 
nagios_hostextinfo - The Nagios type hostextinfo 
nagios_hostgroup - The Nagios type hostgroup 

nagios_service  - The Nagios type service 
nagios_servicedependency - The Nagios type servicedependency 
nagios_serviceescalation - The Nagios type serviceescalation 
nagios_serviceextinfo - The Nagios type serviceextinfo  
nagios_servicegroup - The Nagios type servicegroup 
nagios_timeperiod - The Nagios type timeperiod 
notify          - .. no documentation .. 
package         - Manage packages 
resources       - This is a metatype that can manage other reso ... 
router          - .. no documentation .. 
schedule        - Define schedules for Puppet 
scheduled_task  - Installs and manages Windows Scheduled Tasks 
selboolean      - Manages SELinux booleans on systems with SELi ... 
service         - Manage running services 
ssh_authorized_key - Manages SSH authorized keys 
sshkey          - Installs and manages ssh host keys 
stage           - A resource type for creating new run stages 
tidy            - Remove unwanted files based on specific crite ... 
user            - Manage users 
vlan            - .. no documentation .. 
whit            - Whits are internal artifacts of Puppet's curr ... 
yumrepo         - The client-side description of a yum reposito ... 
zfs             - Manage zfs 
zone            - Manages Solaris zones 
zpool           - Manage zpools

संसाधन शीर्षक

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

संसाधन कमांड का उपयोग टाइप उपयोगकर्ता का उपयोग करके सभी संसाधनों की सूची देखने के लिए किया जा सकता है।

[root@puppetmaster ~]# puppet resource user 
user { 'abrt': 
   ensure           => 'present', 
   gid              => '173', 
   home             => '/etc/abrt', 
   password         => '!!', 
   password_max_age => '-1', 
   password_min_age => '-1', 
   shell            => '/sbin/nologin', 
   uid              => '173', 
} 

user { 'admin': 
   ensure           => 'present', 
   comment          => 'admin', 
   gid              => '444', 
   groups           => ['sys', 'admin'], 
   home             => '/var/admin', 
   password         => '*', 
   password_max_age => '99999', 
   password_min_age => '0', 
   shell            => '/sbin/nologin', 
   uid              => '55', 
} 

user { 'tomcat': 
   ensure           => 'present', 
   comment          => 'tomcat', 
   gid              => '100', 
   home             => '/var/www', 
   password         => '!!', 
   password_max_age => '-1', 
   password_min_age => '-1', 
   shell            => '/sbin/nologin', 
   uid              => '100', 
}

एक विशेष उपयोगकर्ता के संसाधनों की सूची बनाना

[root@puppetmaster ~]# puppet resource user tomcat 
user { 'apache': 
   ensure           => 'present', 
   comment          => 'tomcat', 
   gid              => '100', 
   home             => '/var/www', 
   password         => '!!', 
   password_max_age => '-1', 
   password_min_age => '-1', 
   shell            => '/sbin/nologin', 
   uid              => '100’, 
}

गुण और मूल्य

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

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

[root@puppetmaster ~]# puppet describe user 
user 
==== 
Manage users.  This type is mostly built to manage system users, 
so it is lacking some features useful for managing normal users. 

This resource type uses the prescribed native tools for creating groups 
and generally uses POSIX APIs for retrieving information about them.
It does not directly modify ‘/etc/passwd’ or anything. 

**Autorequires:** If Puppet is managing the user's primary group 
(as provided in the ‘gid’ attribute), 
the user resource will autorequire that group. 
If Puppet is managing any role accounts corresponding to the user's roles, 
the user resource will autorequire those role accounts.  

Parameters 
---------- 
- **allowdupe** 
   Whether to allow duplicate UIDs. Defaults to ‘false’. 
   Valid values are ‘true’, ‘false’, ‘yes’, ‘no’.  

- **attribute_membership** 
   Whether specified attribute value pairs should be treated as the 
   **complete list** (‘inclusive’) or the **minimum list** (‘minimum’) of 
   attribute/value pairs for the user. Defaults to ‘minimum’. 
   Valid values are ‘inclusive’, ‘minimum’.  

- **auths** 
   The auths the user has.  Multiple auths should be 
   specified as an array. 
   Requires features manages_solaris_rbac.  

- **comment** 
   A description of the user.  Generally the user's full name.  

- **ensure** 
   The basic state that the object should be in. 
   Valid values are ‘present’, ‘absent’, ‘role’.  

- **expiry**
   The expiry date for this user. Must be provided in 
   a zero-padded YYYY-MM-DD format --- e.g. 2010-02-19. 
   If you want to make sure the user account does never 
   expire, you can pass the special value ‘absent’. 
   Valid values are ‘absent’. Values can match ‘/^\d{4}-\d{2}-\d{2}$/’. Requires features manages_expiry. - **forcelocal** Forces the mangement of local accounts when accounts are also being managed by some other NSS - **gid** The user's primary group. Can be specified numerically or by name. This attribute is not supported on Windows systems; use the ‘groups’ attribute instead. (On Windows, designating a primary group is only meaningful for domain accounts, which Puppet does not currently manage.) - **groups** The groups to which the user belongs. The primary group should not be listed, and groups should be identified by name rather than by GID. Multiple groups should be specified as an array. - **home** The home directory of the user. The directory must be created separately and is not currently checked for existence. - **ia_load_module** The name of the I&A module to use to manage this user. Requires features manages_aix_lam. - **iterations** This is the number of iterations of a chained computation of the password hash (http://en.wikipedia.org/wiki/PBKDF2). This parameter is used in OS X. This field is required for managing passwords on OS X >= 10.8. Requires features manages_password_salt. - **key_membership** - **managehome** Whether to manage the home directory when managing the user. This will create the home directory when ‘ensure => present’, and delete the home directory when ‘ensure => absent’. Defaults to ‘false’. Valid values are ‘true’, ‘false’, ‘yes’, ‘no’. - **membership** Whether specified groups should be considered the **complete list** (‘inclusive’) or the **minimum list** (‘minimum’) of groups to which the user belongs. Defaults to ‘minimum’. Valid values are ‘inclusive’, ‘minimum’. - **name** The user name. While naming limitations vary by operating system, it is advisable to restrict names to the lowest common denominator, which is a maximum of 8 characters beginning with a letter. Note that Puppet considers user names to be case-sensitive, regardless of the platform's own rules; be sure to always use the same case when referring to a given user. - **password** The user's password, in whatever encrypted format the local system requires. * Most modern Unix-like systems use salted SHA1 password hashes. You can use Puppet's built-in ‘sha1’ function to generate a hash from a password. * Mac OS X 10.5 and 10.6 also use salted SHA1 hashes. Windows API for setting the password hash. [stdlib]: https://github.com/puppetlabs/puppetlabs-stdlib/ Be sure to enclose any value that includes a dollar sign ($) in single 
   quotes (') to avoid accidental variable interpolation. 
   Requires features manages_passwords.  

- **password_max_age** 
   The maximum number of days a password may be used before it must be changed. 
   Requires features manages_password_age.  

- **password_min_age** 
   The minimum number of days a password must be used before it may be changed. 
   Requires features manages_password_age.  

- **profile_membership** 
   Whether specified roles should be treated as the **complete list** 
   (‘inclusive’) or the **minimum list** (‘minimum’) of roles 
   of which the user is a member. Defaults to ‘minimum’. 
   Valid values are ‘inclusive’, ‘minimum’.  

- **profiles** 
   The profiles the user has.  Multiple profiles should be 
   specified as an array. 
   Requires features manages_solaris_rbac.  

- **project** 
   The name of the project associated with a user. 
   Requires features manages_solaris_rbac.  

- **uid** 
   The user ID; must be specified numerically. If no user ID is 
   specified when creating a new user, then one will be chosen 
   automatically. This will likely result in the same user having 
   different UIDs on different systems, which is not recommended. This is 
   especially noteworthy when managing the same user on both Darwin and 
   other platforms, since Puppet does UID generation on Darwin, but 
   the underlying tools do so on other platforms. 
   On Windows, this property is read-only and will return the user's 
   security identifier (SID).

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

संसाधन [R]

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

अमूर्तता [ए]

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

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

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

परत [L]

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

उपयोगकर्ता संसाधन प्रकार के लिए उदाहरण

[root@puppetmaster ~]# puppet describe user --providers 
user 
==== 
Manage users.
This type is mostly built to manage systemusers, 
so it is lacking some features useful for managing normalusers. 
This resource type uses the prescribed native tools for 
creating groups and generally uses POSIX APIs for retrieving informationabout them.
It does not directly modify '/etc/passwd' or anything. 

- **comment** 
   A description of the user.  Generally the user's full name.  

- **ensure** 
   The basic state that the object should be in. 
   Valid values are 'present', 'absent', 'role'.  

- **expiry** 
   The expiry date for this user. 
   Must be provided in a zero-padded YYYY-MM-DD format --- e.g. 2010-02-19. 
   If you want to make sure the user account does never expire, 
   you can pass the special value 'absent'. 
   Valid values are 'absent'. 
   Values can match '/^\d{4}-\d{2}-\d{2}$/'. Requires features manages_expiry. - **forcelocal** Forces the management of local accounts when accounts are also being managed by some other NSS Valid values are 'true', 'false', 'yes', 'no'. Requires features libuser. - **gid** The user's primary group. Can be specified numerically or by name. This attribute is not supported on Windows systems; use the ‘groups’ attribute instead. (On Windows, designating a primary group is only meaningful for domain accounts, which Puppet does not currently manage.) - **groups** The groups to which the user belongs. The primary group should not be listed, and groups should be identified by name rather than by GID. Multiple groups should be specified as an array. - **home** The home directory of the user. The directory must be created separately and is not currently checked for existence. - **ia_load_module** The name of the I&A module to use to manage this user. Requires features manages_aix_lam. - **iterations** This is the number of iterations of a chained computation of the password hash (http://en.wikipedia.org/wiki/PBKDF2). This parameter is used in OS X. This field is required for managing passwords on OS X >= 10.8. - **key_membership** Whether specified key/value pairs should be considered the **complete list** ('inclusive') or the **minimum list** ('minimum') of the user's attributes. Defaults to 'minimum'. Valid values are 'inclusive', 'minimum'. - **keys** Specify user attributes in an array of key = value pairs. Requires features manages_solaris_rbac. - **managehome** Whether to manage the home directory when managing the user. This will create the home directory when 'ensure => present', and delete the home directory when ‘ensure => absent’. Defaults to ‘false’. Valid values are ‘true’, ‘false’, ‘yes’, ‘no’. - **membership** Whether specified groups should be considered the **complete list** (‘inclusive’) or the **minimum list** (‘minimum’) of groups to which the user belongs. Defaults to ‘minimum’. Valid values are ‘inclusive’, ‘minimum’. - **name** The user name. While naming limitations vary by operating system, it is advisable to restrict names to the lowest common denominator. - **password** The user's password, in whatever encrypted format the local system requires. * Most modern Unix-like systems use salted SHA1 password hashes. You can use Puppet's built-in ‘sha1’ function to generate a hash from a password. * Mac OS X 10.5 and 10.6 also use salted SHA1 hashes. * Mac OS X 10.7 (Lion) uses salted SHA512 hashes. The Puppet Labs [stdlib][] module contains a ‘str2saltedsha512’ function which can generate password hashes for Lion. * Mac OS X 10.8 and higher use salted SHA512 PBKDF2 hashes. When managing passwords on these systems the salt and iterations properties need to be specified as well as the password. [stdlib]: https://github.com/puppetlabs/puppetlabs-stdlib/ Be sure to enclose any value that includes a dollar sign ($) in single 
   quotes (') to avoid accidental variable interpolation. 
   Requires features manages_passwords.  

- **password_max_age** 
   The maximum number of days a password may be used before it must be changed. 
Requires features manages_password_age.  

- **password_min_age** 
   The minimum number of days a password must be used before it may be changed. 
Requires features manages_password_age.  

- **profile_membership** 
   Whether specified roles should be treated as the **complete list** 
   (‘inclusive’) or the **minimum list** (‘minimum’) of roles 
   of which the user is a member. Defaults to ‘minimum’. 
   Valid values are ‘inclusive’, ‘minimum’. 

- **profiles** 
   The profiles the user has.  Multiple profiles should be 
   specified as an array. 
Requires features manages_solaris_rbac.  

- **project** 
   The name of the project associated with a user. 
   Requires features manages_solaris_rbac.  

- **purge_ssh_keys** 
   Purge ssh keys authorized for the user 
   if they are not managed via ssh_authorized_keys. 
   When true, looks for keys in .ssh/authorized_keys in the user's home directory. 
   Possible values are true, false, or an array of 
   paths to file to search for authorized keys. 
   If a path starts with ~ or %h, this token is replaced with the user's home directory. 
   Valid values are ‘true’, ‘false’.  

- **role_membership** 
   Whether specified roles should be considered the **complete list** 
   (‘inclusive’) or the **minimum list** (‘minimum’) of roles the user has. 
   Defaults to ‘minimum’. 
Valid values are ‘inclusive’, ‘minimum’.  

- **roles** 
   The roles the user has.  Multiple roles should be 
   specified as an array. 
Requires features manages_solaris_rbac.  

- **salt** 
   This is the 32 byte salt used to generate the PBKDF2 password used in 
   OS X. This field is required for managing passwords on OS X >= 10.8. 
   Requires features manages_password_salt. 

- **shell** 
   The user's login shell.  The shell must exist and be 
   executable. 
   This attribute cannot be managed on Windows systems. 
   Requires features manages_shell. 

- **system** 
   Whether the user is a system user, according to the OS's criteria; 
   on most platforms, a UID less than or equal to 500 indicates a system 
   user. Defaults to ‘false’. 
   Valid values are ‘true’, ‘false’, ‘yes’, ‘no’.  

- **uid** 
   The user ID; must be specified numerically. If no user ID is 
   specified when creating a new user, then one will be chosen 
   automatically. This will likely result in the same user having 
   different UIDs on different systems, which is not recommended. 
   This is especially noteworthy when managing the same user on both Darwin and 
   other platforms, since Puppet does UID generation on Darwin, but 
   the underlying tools do so on other platforms. 
   On Windows, this property is read-only and will return the user's 
   security identifier (SID).  

Providers 
--------- 

- **aix** 
   User management for AIX. 
   * Required binaries: '/bin/chpasswd', '/usr/bin/chuser', 
   '/usr/bin/mkuser', '/usr/sbin/lsgroup', '/usr/sbin/lsuser', 
   '/usr/sbin/rmuser'. 
   * Default for ‘operatingsystem’ == ‘aix’. 
   * Supported features: ‘manages_aix_lam’, ‘manages_expiry’, 
   ‘manages_homedir’, ‘manages_password_age’, ‘manages_passwords’, 
   ‘manages_shell’. 

- **directoryservice** 
   User management on OS X. 
   * Required binaries: ‘/usr/bin/dscacheutil’, ‘/usr/bin/dscl’, 
   ‘/usr/bin/dsimport’, ‘/usr/bin/plutil’, ‘/usr/bin/uuidgen’. 
   * Default for ‘operatingsystem’ == ‘darwin’. 
   * Supported features: ‘manages_password_salt’, ‘manages_passwords’, 
   ‘manages_shell’.

- **hpuxuseradd** 
   User management for HP-UX. This provider uses the undocumented ‘-F’ 
   switch to HP-UX's special ‘usermod’ binary to work around the fact that 
   its standard ‘usermod’ cannot make changes while the user is logged in. 
   * Required binaries: ‘/usr/sam/lbin/useradd.sam’, 
   ‘/usr/sam/lbin/userdel.sam’, ‘/usr/sam/lbin/usermod.sam’. 
   * Default for ‘operatingsystem’ == ‘hp-ux’. 
   * Supported features: ‘allows_duplicates’, ‘manages_homedir’, 
   ‘manages_passwords’.  

- **ldap** 
   User management via LDAP. 
   This provider requires that you have valid values for all of the 
   LDAP-related settings in ‘puppet.conf’, including ‘ldapbase’.
   You will almost definitely need settings for ‘ldapuser’ and ‘ldappassword’ in order 
   for your clients to write to LDAP. 
* Supported features: ‘manages_passwords’, ‘manages_shell’.  

- **pw** 
   User management via ‘pw’ on FreeBSD and DragonFly BSD. 
   * Required binaries: ‘pw’. 
   * Default for ‘operatingsystem’ == ‘freebsd, dragonfly’. 
   * Supported features: ‘allows_duplicates’, ‘manages_expiry’, 
   ‘manages_homedir’, ‘manages_passwords’, ‘manages_shell’. 

- **user_role_add** 
   User and role management on Solaris, via ‘useradd’ and ‘roleadd’. 
   * Required binaries: ‘passwd’, ‘roleadd’, ‘roledel’, ‘rolemod’, 
   ‘useradd’, ‘userdel’, ‘usermod’. 
   * Default for ‘osfamily’ == ‘solaris’. 
   * Supported features: ‘allows_duplicates’, ‘manages_homedir’, 
   ‘manages_password_age’, ‘manages_passwords’, ‘manages_solaris_rbac’.  

- **useradd** 
   User management via ‘useradd’ and its ilk.  Note that you will need to 
   install Ruby's shadow password library (often known as ‘ruby-libshadow’) 
   if you wish to manage user passwords. 
   * Required binaries: ‘chage’, ‘luseradd’, ‘useradd’, ‘userdel’, ‘usermod’. 
   * Supported features: ‘allows_duplicates’, ‘libuser’, ‘manages_expiry’, 
   ‘manages_homedir’, ‘manages_password_age’, ‘manages_passwords’, 
   ‘manages_shell’, ‘system_users’.  

- **windows_adsi** 
   Local user management for Windows. 
   * Default for 'operatingsystem' == 'windows'. 
   * Supported features: 'manages_homedir', 'manages_passwords'.

परीक्षण संसाधन

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

परीक्षण के लिए हम संसाधन को स्थानीय स्तर पर लागू करने जा रहे हैं। जैसा कि हमारे पास उपरोक्त संसाधन पूर्वनिर्धारित हैuser = vipin। संसाधन लगाने का एक तरीका सीएलआई है। यह एक ही कमांड में पूरा संसाधन फिर से लिखने और फिर एक संसाधन उप कमांड में इसे पारित करके किया जा सकता है।

puppet resource user vipin ensure = present uid = '505' 
shell = '/bin/bash' home = '/home/vipin'

लागू संसाधन का परीक्षण करें।

[root@puppetmaster ~]# cat /etc/passwd | grep "vipin" 
vipin:x:505:501::/home/vipin:/bin/bash

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

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

टेम्पलेट्स का मूल्यांकन

टेम्पलेट्स का मूल्यांकन सरल कार्यों का उपयोग करके किया जाता है।

$value = template ("testtemplate.erb")

एक टेम्प्लेट के पूर्ण पथ को निर्दिष्ट कर सकता है या एक पपेट के टेम्प्लेटेडिर में सभी टेम्प्लेट खींच सकता है, जो आमतौर पर / var / कठपुतली / टेम्प्लेट पर स्थित होता है। एक कठपुतली चलाकर निर्देशिका स्थान पा सकते हैं--configprint templatedir।

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

टेम्प्लेट का उपयोग करना

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

define testingsite($cgidir, $tracdir) { file { "testing-$name": 
   path => "/etc/tomcat/testing/$name.conf", owner => superuser, group => superuser, mode => 644, require => File[tomcatconf], content => template("testsite.erb"), notify => Service[tomcat] } symlink { "testsym-$name": 
      path => "$cgidir/$name.cgi", 
      ensure => "/usr/share/test/cgi-bin/test.cgi" 
   } 
}

निम्नलिखित टेम्पलेट परिभाषा है।

<Location "/cgi-bin/ <%= name %>.cgi"> 
   SetEnv TEST_ENV "/export/svn/test/<%= name %>" 
</Location>  

# You need something like this to authenticate users 
<Location "/cgi-bin/<%= name %>.cgi/login"> 
   AuthType Basic 
   AuthName "Test" 
   AuthUserFile /etc/tomcat/auth/svn 
   Require valid-user 
</Location>

यह प्रत्येक टेम्पलेट फ़ाइल को एक अलग फ़ाइल में धकेलता है और फिर इन कॉन्फ़िगरेशन फ़ाइलों को लोड करने के लिए अपाचे को बताने की आवश्यकता होती है।

Include /etc/apache2/trac/[^.#]*

टेंपरेचर को मिलाना

निम्नलिखित कमांड का उपयोग करके दो टेम्पलेट्स को आसानी से जोड़ा जा सकता है।

template('/path/to/template1','/path/to/template2')

टेम्प्लेट में परिवर्तन

कठपुतली टेम्पलेट भी सरणी पुनरावृत्ति का समर्थन करता है। यदि वैरिएबल एक्सेस कर रहा है, तो एक ऐरे है, फिर कोई उस पर पुनरावृति कर सकता है।

$values = [val1, val2, otherval]

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

<% values.each do |val| -%> 
Some stuff with <%= val %> 
<% end -%>

उपरोक्त आदेश निम्नलिखित परिणाम का उत्पादन करेगा।

Some stuff with val1 
Some stuff with val2 
Some stuff with otherval

टेम्प्लेट में स्थितियां

erbtemplating सशर्त समर्थन करता है। निम्नलिखित निर्माण एक त्वरित और आसान तरीका है जो किसी फ़ाइल में सामग्री को सशर्त रूप से रखता है।

<% if broadcast != "NONE" %> broadcast <%= broadcast %> <% end %>

टेम्प्लेट और चर

फ़ाइल सामग्री को भरने के अलावा, चर को भरने के लिए टेम्पलेट का उपयोग किया जा सकता है।

testvariable = template('/var/puppet/template/testvar')

अपरिभाषित चर

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

<% if has_variable?("myvar") then %> 
myvar has <%= myvar %> value 
<% end %>

स्कोप वेरिएबल से बाहर

एक लुकअपियर फ़ंक्शन के साथ स्पष्ट रूप से स्कोप चर के बाहर देख सकते हैं।

<%= scope.lookupvar('apache::user') %>

नमूना परियोजना टेम्पलेट

<#Autogenerated by puppet. Do not edit. 
[default] 
#Default priority (lower value means higher priority) 
priority = <%= @priority %> 
#Different types of backup. Will be done in the same order as specified here. 
#Valid options: rdiff-backup, mysql, command 
backups = <% if @backup_rdiff %>rdiff-backup, 
<% end %><% if @backup_mysql %>mysql, 
<% end %><% if @backup_command %>command<% end %> 
<% if @backup_rdiff -%>  

[rdiff-backup]  

<% if @rdiff_global_exclude_file -%> 
   global-exclude-file = <%= @rdiff_global_exclude_file %> 
<% end -%> 
   <% if @rdiff_user -%> 
      user = <%= @rdiff_user %> 
<% end -%> 
<% if @rdiff_path -%> 
   path = <%= @rdiff_path %> 
<% end -%>  

#Optional extra parameters for rdiff-backup  

extra-parameters = <%= @rdiff_extra_parameters %>  

#How long backups are going to be kept 
keep = <%= @rdiff_keep %> 
<% end -%> 
<% if @backup_mysql -%>%= scope.lookupvar('apache::user') %>  

[mysql]  

#ssh user to connect for running the backup 
sshuser =  <%= @mysql_sshuser %>

#ssh private key to be used 
   sshkey = <%= @backup_home %>/<%= @mysql_sshkey %> 
   <% end -%> 
<% if @backup_command -%>  
[command] 

#Run a specific command on the backup server after the backup has finished  

command = <%= @command_to_execute %> 
<% end -%>

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

निम्नलिखित कठपुतली वर्ग का एक उदाहरण है।

[root@puppetmaster manifests]# cat site.pp  
class f3backup ( 
   $backup_home   = '/backup', 
   $backup_server = 'default', $myname        = $::fqdn, $ensure        = 'directory', 
) { 
   include '::f3backup::common' 
   if ( $myname == '' or $myname == undef ) { 
      fail('myname must not be empty') 
   }  
   @@file { "${backup_home}/f3backup/${myname}": 
      # To support 'absent', though force will be needed 
      ensure => $ensure, owner => 'backup', group => 'backup', mode => '0644', tag => "f3backup-${backup_server}", 
   }
}

उपरोक्त उदाहरण में, हमारे पास दो ग्राहक हैं जहां उपयोगकर्ता को मौजूद होना चाहिए। जैसा कि देखा जा सकता है कि हमने एक ही संसाधन को दो बार दोहराया है। दो नोड्स के संयोजन में एक ही कार्य नहीं करने का एक तरीका।

[root@puppetmaster manifests]# cat site.pp 
node 'Brcleprod001','Brcleprod002' { 
   user { 'vipin': 
      ensure => present, 
      uid    => '101', 
      shell  => '/bin/bash', 
      home   => '/home/homer', 
   } 
}

इस फैशन में कॉन्फ़िगरेशन को निष्पादित करने के लिए नोड्स को जोड़ना एक अच्छा अभ्यास नहीं है। यह केवल एक वर्ग बनाकर और नोड्स में बनाई गई कक्षा को शामिल करके प्राप्त किया जा सकता है जो निम्नानुसार दिखाया गया है।

class vipin_g01063908 { 
   user { 'g01063908': 
      ensure => present, 
      uid    => '101', 
      shell  => '/bin/bash', 
      home   => '/home/g01063908', 
   } 
}  
node 'Brcleprod001' { 
   class {vipin_g01063908:} 
}  
node 'Brcleprod002' { 
   class {vipin_g01063908:} 
}

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

पैरामीटर वर्ग

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

[root@puppetmaster ~]# cat /etc/puppet/manifests/site.pp 
class user_account ($username){ user { $username: 
      ensure => present, 
      uid    => '101', 
      shell  => '/bin/bash', 
      home   => "/home/$username", 
   } 
}  
node 'Brcleprod002' { 
   class { user_account: 
      username => "G01063908", 
   } 
} 
node 'Brcleprod002' { 
   class {user_account: 
      username => "G01063909", 
   } 
}

जब हम उपरोक्त साइट को लागू करते हैं। नोड्स पर प्रकट होते हैं, तो प्रत्येक नोड के लिए आउटपुट निम्न की तरह दिखाई देगा।

Brcleprod001

[root@puppetagent1 ~]# puppet agent --test 
Info: Retrieving pluginfacts 
Info: Retrieving plugin 
Info: Caching catalog for puppetagent1.testing.dyndns.org 
Info: Applying configuration version '1419452655' 

Notice: /Stage[main]/User_account/User[homer]/ensure: created 
Notice: Finished catalog run in 0.15 seconds 
[root@brcleprod001 ~]# cat /etc/passwd | grep "vipin" 
G01063908:x:101:501::/home/G01063909:/bin/bash

Brcleprod002

[root@Brcleprod002 ~]# puppet agent --test 
Info: Retrieving pluginfacts 
Info: Retrieving plugin 
Info: Caching catalog for puppetagent2.testing.dyndns.org 
Info: Applying configuration version '1419452725' 

Notice: /Stage[main]/User_account/User[bart]/ensure: created 
Notice: Finished catalog run in 0.19 seconds 
[root@puppetagent2 ~]# cat /etc/passwd | grep "varsha" 
G01063909:x:101:501::/home/G01063909:/bin/bash

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

[root@puppetmaster ~]# cat /etc/puppet/manifests/site.pp 
class user_account ($username = ‘g01063908'){ 
   user { $username: ensure => present, uid => '101', shell => '/bin/bash', home => "/home/$username", 
   } 
}  
node 'Brcleprod001' { 
   class {user_account:} 
}  
node 'Brcleprod002' { 
   class {user_account: 
      username => "g01063909", 
   } 
}

कठपुतली का आधार विकास भाषा रूबी है क्योंकि कठपुतली किसी अन्य प्रोग्रामिंग भाषा के रूप में कार्यों का समर्थन करती है। यह दो प्रकार के कार्यों का समर्थन करता है जिनके नाम से जाना जाता हैstatement तथा rvalue कार्य करता है।

  • Statementsअपने दम पर खड़े हैं और उनके पास कोई वापसी प्रकार नहीं है। उनका उपयोग नए प्रदर्शन फ़ाइल में अन्य पपेट मॉड्यूल आयात करने जैसे स्टैंडअलोन कार्यों को करने के लिए किया जाता है।

  • Rvalue मान लौटाता है और इसका उपयोग केवल तभी किया जा सकता है जब कथन के लिए मान की आवश्यकता होती है, जैसे असाइनमेंट या केस स्टेटमेंट।

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

फ़ाइल फ़ंक्शन

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

जैसे स्क्रिप्ट / tesingscript.sh <मॉड्यूल नाम> /script/files/testingscript.sh से फाइलों को लोड करेगा। फ़ंक्शन में एक पूर्ण पथ को पढ़ने और स्वीकार करने की क्षमता है, जो डिस्क पर कहीं से भी फ़ाइल को लोड करने में मदद करता है।

फ़ंक्शन शामिल करें

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

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

फ़ंक्शन शामिल करें एक वर्ग को क्लास में समाहित करने का कारण नहीं बनता है जब उन्हें घोषित किया जाता है, इसके लिए हमें एक निहित फ़ंक्शन का उपयोग करने की आवश्यकता होती है। यहां तक ​​कि यह घोषित वर्ग और इसके आस-पास की कक्षाओं में भी निर्भरता पैदा नहीं करता है।

फ़ंक्शन में शामिल हैं, केवल एक वर्ग के पूर्ण नाम की अनुमति है, रिश्तेदार नामों की अनुमति नहीं है।

परिभाषित समारोह

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

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

फ़ंक्शन मिलान को परिभाषित करें

# Matching resource types 
defined("file") 
defined("customtype")  

# Matching defines and classes 
defined("testing") 
defined("testing::java")  

# Matching variables 
defined('$name')  

# Matching declared resources 
defined(File['/tmp/file'])

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

कस्टम फंक्शन लिखना

कुछ चीजें हैं जो एक समारोह लिखने से पहले ध्यान में रखने की जरूरत है।

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

  • कठपुतली मास्टर कस्टम फ़ंक्शन को पकड़ता है, जिसका अर्थ है कि कठपुतली मास्टर को पुनरारंभ करने की आवश्यकता है, अगर कोई कठपुतली फ़ंक्शन में कुछ बदलाव करता है।

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

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

  • फ़ाइल में फ़ंक्शन का नाम फ़ाइल में फ़ंक्शन के नाम के समान होना चाहिए। अन्यथा, यह स्वचालित रूप से लोड नहीं होगा।

कस्टम फंक्शन लगाने का स्थान

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

  • $libdir/puppet/parser/functions
  • अपने रूबी $ LOAD_PATH में कठपुतली / पार्सर / फ़ंक्शन उप-निर्देशिका

एक नया फंक्शन बनाना

नए कार्यों का उपयोग कर बनाया या परिभाषित किया जाता है newfunction के अंदर विधि puppet::parser::Functionsमापांक। एक प्रतीक के रूप में फ़ंक्शन नाम को पास करने की आवश्यकता हैnewfunctionविधि और एक ब्लॉक के रूप में चलाने के लिए कोड। निम्नलिखित उदाहरण एक फ़ंक्शन है, जिसका उपयोग / उपयोगकर्ता निर्देशिका के अंदर फ़ाइल को स्ट्रिंग लिखने के लिए किया जाता है।

module Puppet::Parser::Functions 
   newfunction(:write_line_to_file) do |args| 
      filename = args[0] 
      str = args[1] 
      File.open(filename, 'a') {|fd| fd.puts str } 
   end 
end

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

write_line_to_file('/user/vipin.txt, "Hello vipin!")

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

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

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

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

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

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

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

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

[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

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

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

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

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

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

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

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

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

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

[puppetd] 
environment = Testing

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

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

#puppetd -–environment = testing

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

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

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

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

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

कठपुतली रूबी को अपनी आधार भाषा के रूप में इस्तेमाल करती है। मौजूद सभी कठपुतली प्रकार और प्रदाता रूबी भाषा में लिखे गए हैं। जैसा कि यह मानक एन्कोडिंग प्रारूप का अनुसरण करता है, कोई उन्हें केवल रेपो के उदाहरण में दिखाए गए अनुसार बना सकता है जो रिपॉजिटरी का प्रबंधन करता है। यहां, हम टाइप रेपो और प्रोवाइडर्स svn और git बनाएंगे। रेपो टाइप का पहला हिस्सा खुद टाइप होता है। प्रकार आमतौर पर lib / कठपुतली / प्रकार में संग्रहीत होते हैं। इसके लिए हम एक फाइल बनाएंगे जिसका नाम हैrepo.rb

$ touch repo.rb

फ़ाइल में निम्न सामग्री जोड़ें।

Puppet::Type.newtype(:repo) do  
@doc = "Manage repos"  
   Ensurable   
   newparam(:source) do 
      desc "The repo source"  
      
      validate do |value| 
         if value =~ /^git/ 
            resource[:provider] = :git 
         else 
            resource[:provider] = :svn 
         end 
      end 
      isnamevar 
   end  

   newparam(:path) do 
      desc "Destination path"  
      validate do |value| 
         unless value =~ /^\/[a-z0-9]+/ 
            raise ArgumentError , "%s is not a valid file path" % value 
         end 
      end 
   end 
end

उपरोक्त स्क्रिप्ट में, हमने एक ब्लॉक बनाया है "Puppet::Type.newtype(:repo) do"जो रेपो नाम के साथ एक नए प्रकार का निर्माण करता है। फिर, हमारे पास @doc है जो जो भी विवरण जोड़ना चाहता है उसे जोड़ने में मदद करता है। अगला बयान असाध्य है; यह एक मूल सुनिश्चित संपत्ति बनाता है। कठपुतली प्रकार का उपयोग करता है। ensure कॉन्फ़िगरेशन आइटम की स्थिति का निर्धारण करने के लिए गुण।

उदाहरण

service { "sshd": 
   ensure => present, 
}

सुनिश्चित करने वाला विवरण कठपुतली को तीन विधि को छोड़कर बताता है: प्रदाता में बनाना, नष्ट करना और मौजूद होना। ये विधियाँ निम्नलिखित सुविधाएँ प्रदान करती हैं -

  • संसाधन बनाने के लिए एक कमांड
  • किसी संसाधन को हटाने का आदेश
  • संसाधन के अस्तित्व की जांच करने के लिए एक कमांड

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

अगला, हम स्रोत नामक एक नए पैरामीटर को परिभाषित करते हैं।

newparam(:source) do 
   desc "The repo source" 
   validate do |value| 
      if value =~ /^git/ 
         resource[:provider] = :git 
      else 
         resource[:provider] = :svn 
      end 
   end 
   isnamevar 
end

स्रोत रेपो प्रकार को बताएगा जहां स्रोत रिपॉजिटरी को पुनः प्राप्त / क्लोन / चेकआउट करना है। इसमें, हम एक हुक का भी उपयोग कर रहे हैं जिसे वैलिडेट कहा जाता है। प्रदाता अनुभाग में, हमने git और svn को परिभाषित किया है जो हमारे द्वारा परिभाषित भंडार की वैधता के लिए जाँच करते हैं।

अंत में, कोड में हमने पथ नामक एक और पैरामीटर को परिभाषित किया है।

newparam(:path) do 
   desc "Destination path" 
   validate do |value| 
      unless value =~ /^\/[a-z0-9]+/ 
         raise ArgumentError , "%s is not a valid file path" % value 
      end

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

तोड़फोड़ प्रदाता उपयोग मामला

उपर्युक्त प्रकार का उपयोग करके तोड़फोड़ प्रदाता के साथ शुरू करते हैं।

require 'fileutils' 
Puppet::Type.type(:repo).provide(:svn) do 
   desc "SVN Support"  
   
   commands :svncmd => "svn" 
   commands :svnadmin => "svnadmin"  
   
   def create 
      svncmd "checkout", resource[:name], resource[:path] 
   end  
   
   def destroy 
      FileUtils.rm_rf resource[:path] 
   end  
    
   def exists? 
      File.directory? resource[:path] 
   end 
end

उपरोक्त कोड में, हमारे पास अपफ्रंट डिफाइन है जो हमें चाहिए fileutils पुस्तकालय, आवश्यकता है 'fileutils' जिससे हम विधि का उपयोग करने जा रहे हैं।

अगला, हमने प्रदाता को ब्लॉक कठपुतली के रूप में परिभाषित किया है :: Type.type (: repo) .provide (: svn) करते हैं जो कठपुतली को बताता है कि यह प्रकार के लिए प्रदाता है जिसे रेपो कहा जाता है।

फिर, हमने जोड़ा है descजो प्रदाता को कुछ प्रलेखन जोड़ने की अनुमति देता है। हमने उस कमांड को भी परिभाषित किया है जिसका उपयोग यह प्रदाता करेगा। अगली पंक्ति में, हम संसाधन बनाने, हटाने, और मौजूद होने जैसी सुविधाओं की जाँच कर रहे हैं।

एक संसाधन बनाना

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

repo { "wp": 
   source => "http://g01063908.git.brcl.org/trunk/", 
   path => "/var/www/wp", 
   ensure => present, 
}

कठपुतली कठपुतली मास्टर और कठपुतली एजेंटों दोनों के बीच संचार चैनल के रूप में RESTful API का उपयोग करता है। इस RESTful API तक पहुंचने के लिए मूल URL निम्नलिखित है।

https://brcleprod001:8140/{environment}/{resource}/{key} 
https://brcleprod001:8139/{environment}/{resource}/{key}

अन्य एपीआई सुरक्षा

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

परीक्षण एपीआई

RESTful API कनेक्टिविटी को आराम देने के लिए कर्ल यूटिलिटी को एक बेसिक यूटिलिटी के रूप में इस्तेमाल किया जा सकता है। निम्नलिखित एक उदाहरण है कि हम REST API कर्ल कमांड का उपयोग करके नोड के कैटलॉग को कैसे पुनः प्राप्त कर सकते हैं।

curl --cert /etc/puppet/ssl/certs/brcleprod001.pem --key 
   /etc/puppet/ssl/private_keys/brcleprod001.pem

निम्नलिखित कमांड के सेट में हम सिर्फ एसएसएल सर्टिफिकेट सेट कर रहे हैं, जो एसएसएल निर्देशिका कहां है और उपयोग किए गए नोड के नाम के आधार पर अलग होगा। उदाहरण के लिए, आइए निम्नलिखित कमांड को देखें।

curl --insecure -H 'Accept: yaml' 
https://brcleprod002:8140/production/catalog/brcleprod001

उपरोक्त कमांड में, हम सिर्फ एक हैडर भेजते हैं जो उस प्रारूप या प्रारूप को निर्दिष्ट करता है जिसे हम वापस चाहते हैं और एक कैटलॉग बनाने के लिए एक RESTful URL। brcleprod001 उत्पादन वातावरण में, निम्नलिखित उत्पादन उत्पन्न करेगा।

--- &id001 !ruby/object:Puppet::Resource::Catalog 
aliases: {} 
applying: false 
classes: [] 
...

आइए एक और उदाहरण लेते हैं, जहां हम कठपुतली मास्टर से सीए प्रमाण पत्र प्राप्त करना चाहते हैं। इसे स्वयं के हस्ताक्षरित एसएसएल प्रमाण पत्र के साथ प्रमाणित करने की आवश्यकता नहीं है क्योंकि यह कुछ ऐसा है जो प्रमाणित होने से पहले आवश्यक है।

curl --insecure -H 'Accept: s' https://brcleprod001:8140/production/certificate/ca  

-----BEGIN CERTIFICATE----- 
MIICHTCCAYagAwIBAgIBATANBgkqhkiG9w0BAQUFADAXMRUwEwYDVQQDDAxwdXBw

कठपुतली मास्टर और एजेंट साझा एपीआई संदर्भ

GET /certificate/{ca, other}  

curl -k -H "Accept: s" https://brcelprod001:8140/production/certificate/ca 
curl -k -H "Accept: s" https://brcleprod002:8139/production/certificate/brcleprod002

कठपुतली मास्टर एपीआई संदर्भ

प्रमाणित संसाधन (मान्य, हस्ताक्षरित प्रमाण पत्र आवश्यक)।

कैटलाग

GET /{environment}/catalog/{node certificate name} 

curl -k -H "Accept: pson" https://brcelprod001:8140/production/catalog/myclient

प्रमाणपत्र निरस्तीकरण सूची

GET /certificate_revocation_list/ca 

curl -k -H "Accept: s" https://brcleprod001:8140/production/certificate/ca

प्रमाणपत्र का अनुरोध

GET /{environment}/certificate_requests/{anything} GET 
/{environment}/certificate_request/{node certificate name}  

curl -k -H "Accept: yaml" https://brcelprod001:8140/production/certificate_requests/all 
curl -k -H "Accept: yaml" https://brcleprod001:8140/production/certificate_request/puppetclient

रिपोर्ट एक रिपोर्ट सबमिट करें

PUT /{environment}/report/{node certificate name}  
curl -k -X PUT -H "Content-Type: text/yaml" -d "{key:value}" https://brcleprod002:8139/production

नोड - एक विशिष्ट नोड के संबंध में तथ्य

GET /{environment}/node/{node certificate name}  

curl -k -H "Accept: yaml" https://brcleprod002:8140/production/node/puppetclient

स्थिति - परीक्षण के लिए प्रयुक्त

GET /{environment}/status/{anything}  

curl -k -H "Accept: pson" https://brcleprod002:8140/production/certificate_request/puppetclient

कठपुतली एजेंट एपीआई संदर्भ

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

तथ्यों

GET /{environment}/facts/{anything}  

curl -k -H "Accept: yaml" https://brcelprod002:8139/production/facts/{anything}

Run - ग्राहक को कठपुतली या कठपुतली किक की तरह अद्यतन करने का कारण बनता है।

PUT  /{environment}/run/{node certificate name}  

curl -k -X PUT -H "Content-Type: text/pson" -d "{}" 
https://brcleprod002:8139/production/run/{anything}

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

आइए एक नए मॉड्यूल के निर्माण के साथ शुरू करें।

एक नया मॉड्यूल बनाना

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

# cd /etc/puppet/modules 
# puppet module generate Live-module

Note - कठपुतली मॉड्यूल जेनरेट कमांड के लिए आवश्यक है कि मॉड्यूल-नाम पुप्लेट फोर्ज विनिर्देशों के अनुपालन के लिए [उपयोगकर्ता नाम] - [मॉड्यूल] का प्रारूप ले।

नए मॉड्यूल में कुछ बुनियादी फाइलें शामिल हैं, जिसमें एक मैनिफ़ेस्ट निर्देशिका शामिल है। निर्देशिका में पहले से ही एक नाम शामिल है init.pp, जो मॉड्यूल मुख्य मेनिफ़ेस्ट फ़ाइल है। यह मॉड्यूल के लिए एक खाली वर्ग घोषणा है।

class live-module { 
}

मॉड्यूल में एक टेस्ट डायरेक्टरी भी होती है जिसमें एक मेनिफ़ेस्ट होता है जिसे कहा जाता है init.pp। इस परीक्षण मेनिफ़ेस्ट में लाइव मॉड्यूल मॉड्यूल के संदर्भ में / init.pp शामिल है:

include live-module

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

एक HTTP सर्वर स्थापित करना

Http सर्वर को चलाने के लिए कठपुतली मॉड्यूल आवश्यक पैकेज स्थापित करेगा। इसके लिए संसाधन परिभाषा की आवश्यकता होती है जो httpd संकुल के विन्यास को परिभाषित करती है।

मॉड्यूल की मैनिफ़ेस्ट निर्देशिका में, httpd.pp नामक एक नई मैनिफ़ेस्ट फ़ाइल बनाएँ

# touch test-module/manifests/httpd.pp

इस प्रकटन में हमारे मॉड्यूल के लिए सभी HTTP कॉन्फ़िगरेशन शामिल होंगे। पृथक्करण उद्देश्य के लिए, हम http.pp फाइल को init.pp मेनिफ़ेस्ट फ़ाइल से अलग रखेंगे

हमें httpd.pp मेनिफ़ेस्ट फ़ाइल में निम्न कोड डालना होगा।

class test-module::httpd { 
   package { 'httpd': 
      ensure => installed, 
   } 
}

यह कोड httpd नामक परीक्षण-मॉड्यूल के एक उपवर्ग को परिभाषित करता है, फिर httpd पैकेज के लिए पैकेज संसाधन घोषणा को परिभाषित करता है। यदि आवश्यक पैकेज स्थापित है, तो सुनिश्चित करें => स्थापित विशेषता जांच। यदि स्थापित नहीं है, तो कठपुतली इसे स्थापित करने के लिए यम उपयोगिता का उपयोग करती है। अगला, इस उपवर्ग को हमारी मुख्य अभिव्यक्ति फ़ाइल में शामिल करना है। हमें init.pp मेनिफ़ेस्ट संपादित करने की आवश्यकता है।

class test-module { 
   include test-module::httpd 
}

अब, यह मॉड्यूल का परीक्षण करने का समय है जो निम्नानुसार किया जा सकता है

# puppet apply test-module/tests/init.pp --noop

कठपुतली लागू आदेश लक्ष्य प्रणाली पर प्रकट फ़ाइल में मौजूद कॉन्फ़िगरेशन को लागू करता है। यहां, हम परीक्षण init.pp का उपयोग कर रहे हैं जो मुख्य init.pp को संदर्भित करता है। –ऑनोप कॉन्फ़िगरेशन के सूखे रन को निष्पादित करता है, जो केवल आउटपुट दिखाता है लेकिन वास्तव में कुछ भी नहीं करता है।

निम्नलिखित आउटपुट है।

Notice: Compiled catalog for puppet.example.com in environment 
production in 0.59 seconds 

Notice: /Stage[main]/test-module::Httpd/Package[httpd]/ensure: 
current_value absent, should be present (noop) 

Notice: Class[test-module::Httpd]: Would have triggered 'refresh' from 1 
events 

Notice: Stage[main]: Would have triggered 'refresh' from 1 events 
Notice: Finished catalog run in 0.67 seconds

हाइलाइट लाइन सुनिश्चित => स्थापित विशेषता का परिणाम है। Current_value अनुपस्थित का अर्थ है कि कठपुतली ने httpd पैकेज का पता लगाया है। बिना विकल्प के, कठपुतली httpd पैकेज स्थापित करेगी।

Httpd सर्वर चलाना

Httpd सर्वर स्थापित करने के बाद, हमें अन्य संसाधन मंदी का उपयोग करके सेवा शुरू करने की आवश्यकता है: सेवा

हमें httpd.pp मेनिफ़ेस्ट फ़ाइल को संपादित करने और निम्नलिखित सामग्री को संपादित करने की आवश्यकता है।

class test-module::httpd { 
   package { 'httpd': 
      ensure => installed, 
   } 
   service { 'httpd': 
      ensure => running, 
      enable => true, 
      require => Package["httpd"], 
   } 
}

निम्नलिखित लक्ष्यों की सूची है जो हमने उपरोक्त कोड से हासिल की है।

  • ensure => रनिंग स्टेटस चेक करता है कि क्या सर्विस चल रही है, अगर नहीं तो यह इसे इनेबल करता है।

  • enable => सच्ची विशेषता सेवा को तब सेट करती है जब सिस्टम बूट होता है।

  • require => Package["httpd"]विशेषता एक संसाधन मंदी और अन्य के बीच एक आदेश संबंध को परिभाषित करता है। उपरोक्त मामले में, यह सुनिश्चित करता है कि http पैकेज स्थापित होने के बाद httpd सेवा शुरू होती है। यह सेवा और संबंधित पैकेज के बीच एक निर्भरता बनाता है।

फिर से परिवर्तनों का परीक्षण करने के लिए कठपुतली लागू आदेश चलाएँ।

# puppet apply test-module/tests/init.pp --noop 
Notice: Compiled catalog for puppet.example.com in environment 
production in 0.56 seconds 

Notice: /Stage[main]/test-module::Httpd/Package[httpd]/ensure: 
current_value absent, should be present (noop) 

Notice: /Stage[main]/test-module::Httpd/Service[httpd]/ensure: 
current_value stopped, should be running (noop) 

Notice: Class[test-module::Httpd]: Would have triggered 'refresh' from 2 
events 

Notice: Stage[main]: Would have triggered 'refresh' from 1 events 
Notice: Finished catalog run in 0.41 seconds

Httpd सर्वर को कॉन्फ़िगर करना

एक बार उपरोक्त चरण पूरा हो जाने के बाद, हमारे पास HTTP सर्वर स्थापित और सक्षम होगा। अगला कदम सर्वर को कुछ कॉन्फ़िगरेशन प्रदान करना है। डिफ़ॉल्ट रूप से, httpd /etc/httpd/conf/httpd.conf में कुछ डिफ़ॉल्ट कॉन्फ़िगरेशन प्रदान करता है जो एक वेबहोस्ट पोर्ट 80 प्रदान करता है। हम वेब-होस्ट को कुछ उपयोगकर्ता-विशिष्ट सुविधाएं प्रदान करने के लिए कुछ अतिरिक्त होस्ट जोड़ेंगे।

एक टेम्पलेट का उपयोग अतिरिक्त पोर्ट प्रदान करने के लिए किया जाएगा क्योंकि इसके लिए एक चर इनपुट की आवश्यकता होती है। हम एक निर्देशिका नामक टेम्पलेट बनाएंगे और नए निर्देशक में test-server.config.erb नामक एक फ़ाइल जोड़ेंगे और निम्नलिखित सामग्री जोड़ेंगे।

Listen <%= @httpd_port %> 
NameVirtualHost *:<% = @httpd_port %> 

<VirtualHost *:<% = @httpd_port %>> 
   DocumentRoot /var/www/testserver/ 
   ServerName <% = @fqdn %> 
   
   <Directory "/var/www/testserver/"> 
      Options All Indexes FollowSymLinks 
      Order allow,deny 
      Allow from all 
   </Directory> 
</VirtualHost>

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

प्रत्येक संबंधित सिस्टम की कठपुतली सूची तैयार करने से पहले सिस्टम सिस्टम से तथ्य एकत्र किए जाते हैं। कठपुतली इस जानकारी को प्राप्त करने के लिए फैक्टर कमांड का उपयोग करता है और एक सिस्टम के संबंध में अन्य विवरण प्राप्त करने के लिए फैक्टर का उपयोग कर सकता है। हमें httpd.pp मेनिफ़ेस्ट फ़ाइल में हाइलाइट लाइनें जोड़ने की आवश्यकता है।

class test-module::httpd { 
   package { 'httpd': 
      ensure => installed, 
   } 
   service { 'httpd': 
      ensure => running, 
      enable => true, 
      require => Package["httpd"], 
   } 
   file {'/etc/httpd/conf.d/testserver.conf': 
      notify => Service["httpd"], 
      ensure => file, 
      require => Package["httpd"], 
      content => template("test-module/testserver.conf.erb"), 
   } 
   file { "/var/www/myserver": 
      ensure => "directory", 
   } 
}

यह निम्नलिखित चीजों को प्राप्त करने में मदद करता है -

  • यह सर्वर कॉन्फ़िगरेशन फ़ाइल (/etc/httpd/conf.d/test-server.conf) के लिए फ़ाइल संसाधन घोषणा जोड़ता है। इस फ़ाइल की सामग्री परीक्षण-serverconf.erb टेम्पलेट है जो पहले बनाई गई थी। हम इस फ़ाइल को जोड़ने से पहले स्थापित httpd पैकेज की भी जाँच करते हैं।

  • यह दूसरी फ़ाइल संसाधन घोषणा को जोड़ता है जो वेब सर्वर के लिए एक निर्देशिका (/ var / www / परीक्षण-सर्वर) बनाता है।

  • अगला, हम कॉन्फ़िगरेशन फ़ाइल और https सेवा के बीच संबंध जोड़ते हैं notify => Service["httpd"]attribute। यह जाँच करता है कि कोई कॉन्फ़िगरेशन फ़ाइल परिवर्तन हैं या नहीं। अगर वहाँ है, तो कठपुतली सेवा को फिर से शुरू करता है।

अगला है httpd_port को मुख्य मेनिफ़ेस्ट फ़ाइल में शामिल करना। इसके लिए, हमें मुख्य init.pp मेनिफ़ेस्ट फ़ाइल को समाप्त करने और निम्न सामग्री को शामिल करने की आवश्यकता है।

class test-module ( 
   $http_port = 80 
) { 
   include test-module::httpd 
}

यह httpd पोर्ट को 80 के डिफ़ॉल्ट मान पर सेट करता है। अगला पपेट अप कमांड को चलाने के लिए है।

निम्नलिखित उत्पादन होगा।

# puppet apply test-module/tests/init.pp --noop 
Warning: Config file /etc/puppet/hiera.yaml not found, using Hiera 
defaults 

Notice: Compiled catalog for puppet.example.com in environment 
production in 0.84 seconds 

Notice: /Stage[main]/test-module::Httpd/File[/var/www/myserver]/ensure: 
current_value absent, should be directory (noop) 

Notice: /Stage[main]/test-module::Httpd/Package[httpd]/ensure: 
current_value absent, should be present (noop) 

Notice: 
/Stage[main]/test-module::Httpd/File[/etc/httpd/conf.d/myserver.conf]/ensure: 
current_value absent, should be file (noop) 

Notice: /Stage[main]/test-module::Httpd/Service[httpd]/ensure: 
current_value stopped, should be running (noop) 

Notice: Class[test-module::Httpd]: Would have triggered 'refresh' from 4 
events 

Notice: Stage[main]: Would have triggered 'refresh' from 1 events 
Notice: Finished catalog run in 0.51 seconds

फ़ायरवॉल को कॉन्फ़िगर करना

सर्वर से संवाद करने के लिए एक खुले पोर्ट की आवश्यकता होती है। यहां समस्या यह है कि विभिन्न प्रकार के ऑपरेटिंग सिस्टम फ़ायरवॉल को नियंत्रित करने के विभिन्न तरीकों का उपयोग करते हैं। लिनक्स के मामले में, 6 से नीचे के संस्करण iptables का उपयोग करते हैं और संस्करण 7 फायरवॉल का उपयोग करते हैं।

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

इसे प्राप्त करने के लिए, हमें testmodule :: http वर्ग के अंदर निम्नलिखित कोड स्निपेट जोड़ना होगा।

if $operatingsystemmajrelease <= 6 { 
   exec { 'iptables': 
      command => "iptables -I INPUT 1 -p tcp -m multiport --ports 
      ${httpd_port} -m comment --comment 'Custom HTTP Web Host' -j ACCEPT && iptables-save > /etc/sysconfig/iptables", path => "/sbin", refreshonly => true, subscribe => Package['httpd'], } service { 'iptables': ensure => running, enable => true, hasrestart => true, subscribe => Exec['iptables'], } } elsif $operatingsystemmajrelease == 7 { 
   exec { 'firewall-cmd': 
      command => "firewall-cmd --zone=public --addport = $ { 
      httpd_port}/tcp --permanent", 
      path => "/usr/bin/", 
      refreshonly => true, 
      subscribe => Package['httpd'], 
   } 
   service { 'firewalld': 
      ensure => running, 
      enable => true, 
      hasrestart => true, 
      subscribe => Exec['firewall-cmd'], 
   } 
}

उपरोक्त कोड निम्नलिखित कार्य करता है -

  • का उपयोग करते हुए operatingsystemmajrelease निर्धारित करता है कि जो OS उपयोग किया गया है वह संस्करण 6 या 7 है।

  • यदि संस्करण 6 है, तो यह लिनक्स 6 संस्करण को कॉन्फ़िगर करने के लिए सभी आवश्यक कॉन्फ़िगरेशन कमांड चलाता है।

  • यदि ओएस संस्करण 7 है, तो यह फ़ायरवॉल को कॉन्फ़िगर करने के लिए आवश्यक सभी आवश्यक कमांड चलाता है।

  • दोनों ओएस के लिए कोड स्निपेट में एक तर्क होता है जो सुनिश्चित करता है कि कॉन्फ़िगरेशन http पैकेज स्थापित होने के बाद ही चलता है।

अंत में, कठपुतली लागू आदेश चलाएँ।

# puppet apply test-module/tests/init.pp --noop 
Warning: Config file /etc/puppet/hiera.yaml not found, using Hiera 
defaults 

Notice: Compiled catalog for puppet.example.com in environment 
production in 0.82 seconds 

Notice: /Stage[main]/test-module::Httpd/Exec[iptables]/returns: 
current_value notrun, should be 0 (noop) 

Notice: /Stage[main]/test-module::Httpd/Service[iptables]: Would have 
triggered 'refresh' from 1 events

SELinux को कॉन्फ़िगर करना

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

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

exec { 'semanage-port': 
   command => "semanage port -a -t http_port_t -p tcp ${httpd_port}", 
   path => "/usr/sbin", 
   require => Package['policycoreutils-python'], 
   before => Service ['httpd'], 
   subscribe => Package['httpd'], 
   refreshonly => true, 
} 

package { 'policycoreutils-python': 
   ensure => installed, 
}

उपरोक्त कोड निम्नलिखित कार्य करता है -

  • आवश्यकता => पैकेज ['पॉलीसाइकोरिल्स-पायथन'] यह सुनिश्चित करता है कि हमारे पास आवश्यक पायथन मॉड्यूल स्थापित हो।

  • कठपुतली httpd_port का उपयोग करके पोर्ट को खोलने के लिए वीर्यपात का उपयोग करता है।

  • Httpd सेवा शुरू होने से पहले => सेवा इस कमांड को निष्पादित करना सुनिश्चित करती है। यदि HTTPD SELinux कमांड से पहले शुरू होता है, तो SELinux सेवा अनुरोध और सेवा अनुरोध विफल हो जाता है।

अंत में, कठपुतली लागू आदेश चलाएँ

# puppet apply test-module/tests/init.pp --noop 
... 
Notice: /Stage[main]/test-module::Httpd/Package[policycoreutilspython]/ 
ensure: current_value absent, should be present (noop) 
...
Notice: /Stage[main]/test-module::Httpd/Exec[semanage-port]/returns: 
current_value notrun, should be 0 (noop) 
... 
Notice: /Stage[main]/test-module::Httpd/Service[httpd]/ensure: 
current_value stopped, should be running (noop)

कठपुतली पहले अजगर मॉड्यूल को स्थापित करती है और फिर पोर्ट एक्सेस को कॉन्फ़िगर करती है और आखिरकार httpd सेवा शुरू करती है।

वेब होस्ट में HTML फ़ाइलें कॉपी करना

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

फ़ाइलों निर्देशिका के अंदर एक index.html फ़ाइल बनाएँ।

<html> 
   <head> 
      <title>Congratulations</title> 
   <head> 
   
   <body> 
      <h1>Congratulations</h1> 
      <p>Your puppet module has correctly applied your configuration.</p> 
   </body> 
</html>

मैनिफ़ेस्ट डायरेक्टरी के अंदर एक मेनिफ़ेस्ट ऐप बनाएं। निम्न सामग्री जोड़ें।

class test-module::app { 
   file { "/var/www/test-server/index.html": 
      ensure => file, 
      mode => 755, 
      owner => root, 
      group => root, 
      source => "puppet:///modules/test-module/index.html", 
      require => Class["test-module::httpd"], 
   } 
}

इस नए वर्ग में एक एकल संसाधन मंदी है। यह मॉड्यूल की फ़ाइल निर्देशिका से वेब सर्वर पर एक फ़ाइल की प्रतिलिपि बनाता है और इसकी अनुमति देता है। आवश्यक विशेषता परीक्षण-मॉड्यूल को सुनिश्चित करती है :: http- परीक्षण के मॉड्यूल-ऐप को लागू करने से पहले http वर्ग सफलतापूर्वक कॉन्फ़िगरेशन को पूरा करता है।

अंत में, हमें अपने मुख्य init.pp मेनिफेस्ट में एक नया प्रकटन शामिल करना होगा।

class test-module ( 
   $http_port = 80 
) { 
   include test-module::httpd 
   include test-module::app 
}

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

# puppet apply test-module/tests/init.pp --noop
Warning: Config file /etc/puppet/hiera.yaml not found, using Hiera 
defaults 

Notice: Compiled catalog for brcelprod001.brcle.com in environment 
production in 0.66 seconds 

Notice: /Stage[main]/Test-module::Httpd/Exec[iptables]/returns: 
current_value notrun, should be 0 (noop) 

Notice: /Stage[main]/Test-module::Httpd/Package[policycoreutilspython]/ 
ensure: current_value absent, should be present (noop) 

Notice: /Stage[main]/Test-module::Httpd/Service[iptables]: Would have 
triggered 'refresh' from 1 events 

Notice: /Stage[main]/Test-module::Httpd/File[/var/www/myserver]/ensure: 
current_value absent, should be directory (noop) 

Notice: /Stage[main]/Test-module::Httpd/Package[httpd]/ensure: 
current_value absent, should be present (noop) 

Notice: 
/Stage[main]/Test-module::Httpd/File[/etc/httpd/conf.d/myserver.conf]/ensur 
e: current_value absent, should be file (noop) 

Notice: /Stage[main]/Test-module::Httpd/Exec[semanage-port]/returns: 
current_value notrun, should be 0 (noop) 

Notice: /Stage[main]/Test-module::Httpd/Service[httpd]/ensure: 
current_value stopped, should be running (noop) 

Notice: Class[test-module::Httpd]: Would have triggered 'refresh' from 8 
Notice: 
/Stage[main]/test-module::App/File[/var/www/myserver/index.html]/ensur: 
current_value absent, should be file (noop) 

Notice: Class[test-module::App]: Would have triggered 'refresh' from 1 
Notice: Stage[main]: Would have triggered 'refresh' from 2 events Notice: 
Finished catalog run in 0.74 seconds

हाइलाइट की गई रेखा वेब-होस्ट में index.html फ़ाइल के कॉपी होने का परिणाम दिखाती है।

मॉड्यूल को अंतिम रूप देना

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

# puppet module build test-module