शेफ - डेटा बैग के लिए लिपियों

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

इसके लिए किसी के पास कुकबुक होना जरूरी है। हमारे मामले में हम पहले की तरह test_cookbook का उपयोग करेंगे और इसमें नोड की रन सूची होनी चाहिए जिसमें test_cookbook की परिभाषा शामिल है।

कार्य विधि

Step 1 - एक डाटा बैग बनाएं।

vipin@laptop:~/chef-repo $ mkdir data_bags/servers 
vipin@laptop:~/chef-repo $ knife data bag create servers 
Created data_bag[servers]

Step 2 - डेटा बैग आइटम बनाएं।

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

Step 3 - डेटा बैग आइटम को अपडेट करें।

vipin@laptop:~/chef-repo $ subl data_bags/servers/Storage.json { 
   "id": "storage", 
   "host": "10.0.0.12" 
}

कुकबुक में उपयोग करना

Step 1 - उपरोक्त कुकबुक का उपयोग करते हुए डेटा बैग मूल्यों वाले JSON फ़ाइल बनाने की आवश्यकता है ताकि बाहरी स्क्रिप्ट उन मूल्यों तक पहुंच सकें।

vipin@laptop:~/chef-repo $ subl cookbooks/test_cookbook/recipes/default.rb 
file "/etc/backup_config.json" do 
   owner "root"
   group "root" 
   mode 0644 
   content data_bag_item('servers', 'backup')['host'].to_json 
end

Step 2 - Chef सर्वर पर test_cookbook अपलोड करें।

vipin@laptop:~/chef-repo $ knife cookbook upload test_cookbook 
Uploading my_cookbook [0.1.0]

Step 3 - नोड क्लाइंट को नोड पर चलाएँ।

user@server:~$ sudo chef-client 
...TRUNCATED OUTPUT... 
[2013-03-14T20:30:33+00:00] INFO: Processing 
file[/etc/backup_config.json] action create 
(my_cookbook::default line 9) 
[2013-03-14T20:30:34+00:00] INFO: entered create 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] owner changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] group changed to 0 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] mode changed to 644 
[2013-03-14T20:30:34+00:00] INFO: 
file[/etc/backup_config.json] created file 
/etc/backup_config.json 
...TRUNCATED OUTPUT...

Step 4 - उत्पन्न JSON फ़ाइल की सामग्री को मान्य करना।

user@server:~$ cat /etc/backup_config.json 
"10.0.0.12"

लिपियों का वर्कफ़्लो

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