बावर्ची - सोलो सेटअप

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

स्थानीय मशीन पर शेफ-सोलो चलाने से पहले, एक को स्थानीय मशीन पर निम्नलिखित दो फाइलें स्थापित करने की आवश्यकता होती है।

  • Solo.rb - यह फाइल शेफ को बताती है कि कहां से कुकबुक, रोल्स और डेटा बैग मिलेंगे।

  • Node.json - यह फ़ाइल यदि आवश्यक हो तो रन सूची और किसी भी नोड-विशिष्ट विशेषता को सेट करती है।

एकल.rb कॉन्फ़िगरेशन

निम्नलिखित एकल कॉन्फ़िगर करने के लिए कदम हैं।

Step 1 - शेफ रेपो के अंदर एक एकल। आरबी फ़ाइल बनाएँ।

current_dir       = File.expand_path(File.dirname(__FILE__)) 
file_cache_path   "#{current_dir}" 
cookbook_path     "#{current_dir}/cookbooks" 
role_path         "#{current_dir}/roles" 
data_bag_path     "#{current_dir}/data_bags"

Step 2 - फाइल को git repo में जोड़ें।

$ git add solo.rb

Step 3 - निम्न सामग्री के साथ शेफ रेपो के अंदर एक नोड .json फ़ाइल बनाएँ।

{ 
   "run_list": [ "recipe[ntp]" ] 
}

Step 4 - चाकू का उपयोग करके शेफ रेपो के अंदर एनटीपी कुकबुक प्राप्त करें।

vipin@laptop:~/chef-repo $ knife cookbook site install ntp 
Installing ntp to /Users/mma/work/chef-repo/cookbooks 
…TRUNCATED OUTPUT… 
Cookbook ntp version 1.3.0 successfully installed

Step 5 - Git में नोड.जेसन फ़ाइल जोड़ें।

$ git add node.json

Step 6 - रेपो को हटाने के लिए फाइलों को कमिट करें और आगे बढ़ाएं।

vipin@laptop:~/chef-repo $ git commit -m "initial setup for Chef Solo" 
vipin@laptop:~/chef-repo $ git push 
Counting objects: 4, done. 
Delta compression using up to 4 threads. 
...TRUNCATED OUTPUT... 
To [email protected]:mmarschall/chef-repo.git 
b930647..5bcfab6 master -> master

नोड पर कुकबुक चल रहा है

Step 1 - उस नोड पर लॉगिन करें जहां कोई शेफ-सोलो को प्रावधान करना चाहता है।

Step 2 - मशीन पर शेफ रेपो को क्लोन करें।

$ git clone $URL_PATH

Step 3 - महाराज रेपो को सीडी।

$ cd chef-repo

अंत में, नोड को परिवर्तित करने के लिए शेफ-सोलो चलाएं -

$ sudo chef-solo -c solo.rb -j node.json 
[2017-20-08T22:54:13+01:00] INFO: *** Chef 11.0.0 *** 
[2017-20-08T22:54:13+01:00] INFO: Setting the run_list to 
["recipe[ntp]"] from JSON 
...TRUNCATED OUTPUT... 
[2012-12-08T22:54:16+01:00] INFO: Chef Run complete in 2.388374 
seconds 
[2012-12-08T22:54:16+01:00] INFO: Running report handlers

solo.rb शेफ-सोलो को इसकी कुकबुक, भूमिका और डेटा बैग के लिए वर्तमान निर्देशिका के अंदर देखने के लिए कॉन्फ़िगर करता है: शेफ रिपॉजिटरी।

Chef-SoloJSON फ़ाइल से इसका नोड कॉन्फ़िगरेशन लेता है। हमारे उदाहरण में, हमने इसे node.json कहा है। यदि आप कई सर्वरों का प्रबंधन करने जा रहे हैं, तो आपको प्रत्येक नोड के लिए एक अलग फाइल की आवश्यकता होगी। उसके बाद, शेफ-सोलो सिर्फ सोलो.आरबी और नोड.जॉसन में पाए गए कॉन्फ़िगरेशन डेटा के आधार पर एक शेफ रन निष्पादित करता है।