Wayang - Template

Templatingadalah metode untuk mendapatkan sesuatu dalam format standar, yang dapat digunakan di banyak lokasi. Dalam Puppet, templating dan template didukung menggunakan erb yang merupakan bagian dari pustaka standar Ruby, yang dapat digunakan pada proyek lain selain Ruby seperti di proyek Ruby on Rails. Sebagai praktik standar, seseorang harus memiliki pemahaman dasar tentang Ruby. Pembuatan template sangat membantu saat pengguna mencoba mengelola konten file template. Template memainkan peran kunci ketika konfigurasi tidak dapat dikelola oleh tipe Puppet built-in.

Mengevaluasi Template

Template dievaluasi menggunakan fungsi sederhana.

$value = template ("testtemplate.erb")

Seseorang dapat menentukan path lengkap dari sebuah template atau seseorang dapat menarik semua template di templatedir Puppet, yang biasanya terletak di / var / puppet / templates. Anda dapat menemukan lokasi direktori dengan menjalankan puppet –-configprint templatedir.

Template selalu dievaluasi oleh parser, bukan klien yang berarti bahwa jika seseorang menggunakan puppetmasterd, maka template tersebut hanya perlu ada di server dan tidak perlu mendownloadnya ke klien. Tidak ada perbedaan tentang bagaimana klien melihat antara menggunakan template dan menentukan semua konten file sebagai string. Ini jelas menunjukkan bahwa variabel khusus klien dipelajari pertama kali oleh dalang selama fase memulai boneka.

Menggunakan Template

Berikut adalah contoh pembuatan konfigurasi kucing jantan untuk situs pengujian.

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" 
   } 
}

Berikut adalah definisi templatenya.

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

Ini mendorong setiap file template ke file terpisah dan kemudian seseorang hanya perlu memberi tahu Apache untuk memuat file konfigurasi ini.

Include /etc/apache2/trac/[^.#]*

Menggabungkan Template

Dua templat dapat dengan mudah digabungkan menggunakan perintah berikut.

template('/path/to/template1','/path/to/template2')

Iterasi dalam Template

Template boneka juga mendukung iterasi array. Jika variabel yang diakses adalah array, maka seseorang dapat mengulanginya.

$values = [val1, val2, otherval]

Kami dapat memiliki template seperti berikut.

<% values.each do |val| -%> 
Some stuff with <%= val %> 
<% end -%>

Perintah di atas akan menghasilkan hasil sebagai berikut.

Some stuff with val1 
Some stuff with val2 
Some stuff with otherval

Ketentuan di Template

Itu erbtemplate mendukung kondisional. Konstruksi berikut adalah cara cepat dan mudah untuk meletakkan konten secara bersyarat di dalam file.

<% if broadcast != "NONE" %> broadcast <%= broadcast %> <% end %>

Template dan Variabel

Seseorang dapat menggunakan template untuk mengisi variabel selain untuk mengisi konten file.

testvariable = template('/var/puppet/template/testvar')

Variabel Tak Terdefinisi

Jika seseorang perlu memeriksa apakah variabel ditentukan sebelum menggunakannya, perintah berikut berfungsi.

<% if has_variable?("myvar") then %> 
myvar has <%= myvar %> value 
<% end %>

Variabel Di Luar Cakupan

Seseorang dapat mencari variabel di luar cakupan secara eksplisit dengan fungsi lookupvar.

<%= scope.lookupvar('apache::user') %>

Contoh Template Proyek

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