शेफ - डेटा बैग के लिए लिपियों
कुछ स्थितियों में, सर्वर को शेफ के पूर्ण नियंत्रण में रखना संभव नहीं है। ऐसे मामलों में, किसी को स्क्रिप्ट से शेफ डेटा बैग में मूल्यों तक पहुंचने की आवश्यकता हो सकती है। ऐसा करने के लिए, किसी को 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- परिवर्तित मानों को अपनी सामग्री के रूप में उपयोग करता है और इसे डिस्क पर लिखता है।