कठपुतली - लाइव प्रोजेक्ट
कठपुतली नोड पर कॉन्फ़िगरेशन और मैनिफ़ेस्ट लागू करने का लाइव परीक्षण करने के लिए, हम एक लाइव वर्किंग डेमो का उपयोग करेंगे। कॉन्फ़िगरेशन को कैसे काम करता है यह जांचने के लिए इसे सीधे कॉपी और पेस्ट किया जा सकता है। यदि उपयोगकर्ता कोड के एक ही सेट का उपयोग करना चाहता है, तो उसे उसी नामकरण सम्मेलन की आवश्यकता है जो कोड स्निपेट में निम्नानुसार दिखाया गया है।
आइए एक नए मॉड्यूल के निर्माण के साथ शुरू करें।
एक नया मॉड्यूल बनाना
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 फ़ंक्शन को प्रबंधित करने के लिए कुछ संसाधन प्रकार होते हैं, जैसे कि Booleans और मॉड्यूल। यहां, हमें पोर्ट सेटिंग्स को प्रबंधित करने के लिए सीमेन कमांड को निष्पादित करना होगा। यह उपकरण पॉलीसाइकोरिल्स-पायथन पैकेज का एक हिस्सा है, जो डिफ़ॉल्ट रूप से रेड-हैट सर्वर पर स्थापित नहीं है। उपरोक्त प्राप्त करने के लिए, हमें परीक्षण मॉड्यूल के अंदर निम्नलिखित कोड जोड़ने की आवश्यकता है :: 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 का उपयोग करके पोर्ट को खोलने के लिए वीर्यपात का उपयोग करता है।
HTTP सेवा शुरू होने से पहले => सेवा इस कमांड को निष्पादित करना सुनिश्चित करती है। यदि 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>
एक मैनिफ़ेस्ट app बनाएँ। मेनिफ़ेस्ट डायरेक्टरी के अंदर और निम्न सामग्री जोड़ें।
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