कठपुतली - टेम्पलेट

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

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

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

$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 -%>