Wayang - Jenis dan Penyedia

Jenis boneka digunakan untuk manajemen konfigurasi individu. Wayang memiliki tipe yang berbeda-beda seperti tipe jasa, tipe paket, tipe provider, dll. Dimana setiap tipe memiliki provider. Penyedia menangani konfigurasi pada platform atau alat yang berbeda. Misalnya, tipe paket memiliki penyedia aptitude, yum, rpm, dan DGM. Ada banyak jenis dan Puppet mencakup item manajemen konfigurasi spektrum yang baik yang perlu dikelola.

Wayang menggunakan Ruby sebagai bahasa dasarnya. Semua jenis dan penyedia Wayang yang ada ditulis dalam bahasa Ruby. Karena mengikuti format pengkodean standar, seseorang dapat dengan mudah membuatnya seperti yang ditunjukkan pada contoh untuk repo yang mengelola repositori. Di sini, kita akan membuat repo tipe dan provider svn dan git. Bagian pertama dari tipe repo adalah tipe itu sendiri. Jenis biasanya disimpan di lib / puppet / type. Untuk ini, kami akan membuat file bernamarepo.rb.

$ touch repo.rb

Tambahkan konten berikut di file.

Puppet::Type.newtype(:repo) do  
@doc = "Manage repos"  
   Ensurable   
   newparam(:source) do 
      desc "The repo source"  
      
      validate do |value| 
         if value =~ /^git/ 
            resource[:provider] = :git 
         else 
            resource[:provider] = :svn 
         end 
      end 
      isnamevar 
   end  

   newparam(:path) do 
      desc "Destination path"  
      validate do |value| 
         unless value =~ /^\/[a-z0-9]+/ 
            raise ArgumentError , "%s is not a valid file path" % value 
         end 
      end 
   end 
end

Pada skrip di atas, kami telah membuat blok "Puppet::Type.newtype(:repo) do"yang membuat tipe baru dengan nama repo. Kemudian, kami memiliki @doc yang membantu dalam menambahkan tingkat detail apa pun yang ingin ditambahkan. Pernyataan berikutnya adalah Ensurable; ini membuat properti memastikan dasar. Jenis boneka menggunakan ensure properti untuk menentukan status item konfigurasi.

Contoh

service { "sshd": 
   ensure => present, 
}

Pernyataan sure memberi tahu Puppet untuk kecuali tiga metode: buat, hancurkan, dan ada di penyedia. Metode ini menyediakan fitur-fitur berikut -

  • Perintah untuk membuat sumber daya
  • Perintah untuk menghapus sumber daya
  • Perintah untuk memeriksa keberadaan sumber daya

Yang perlu kita lakukan adalah menentukan metode ini dan isinya. Wayang menciptakan infrastruktur pendukung di sekitar mereka.

Selanjutnya, kami mendefinisikan parameter baru yang disebut source.

newparam(:source) do 
   desc "The repo source" 
   validate do |value| 
      if value =~ /^git/ 
         resource[:provider] = :git 
      else 
         resource[:provider] = :svn 
      end 
   end 
   isnamevar 
end

Sumber akan memberi tahu tipe repo tempat untuk mengambil / menggandakan / memeriksa repositori sumber. Dalam hal ini, kami juga menggunakan hook yang disebut validate. Di bagian provider, kita telah mendefinisikan git dan svn yang memeriksa validitas repositori yang telah kita tentukan.

Terakhir, dalam kode kita telah mendefinisikan satu parameter lagi yang disebut path.

newparam(:path) do 
   desc "Destination path" 
   validate do |value| 
      unless value =~ /^\/[a-z0-9]+/ 
         raise ArgumentError , "%s is not a valid file path" % value 
      end

Ini adalah tipe nilai yang menentukan di mana harus meletakkan kode baru yang diambil. Di sini, sekali lagi gunakan hook validasi untuk membuat blok yang memeriksa nilai kesesuaian.

Kasus Penggunaan Penyedia Subversion

Mari kita mulai dengan penyedia subversi menggunakan tipe yang dibuat di atas.

require 'fileutils' 
Puppet::Type.type(:repo).provide(:svn) do 
   desc "SVN Support"  
   
   commands :svncmd => "svn" 
   commands :svnadmin => "svnadmin"  
   
   def create 
      svncmd "checkout", resource[:name], resource[:path] 
   end  
   
   def destroy 
      FileUtils.rm_rf resource[:path] 
   end  
    
   def exists? 
      File.directory? resource[:path] 
   end 
end

Dalam kode di atas, kami telah menentukan dimuka yang kami butuhkan fileutils perpustakaan, membutuhkan 'fileutils' dari mana kita akan menggunakan metode.

Selanjutnya, kami telah mendefinisikan penyedia sebagai blok Puppet :: Type.type (: repo) .provide (: svn) do yang memberi tahu Puppet bahwa ini adalah penyedia untuk tipe yang disebut repo.

Kemudian, kami telah menambahkan descyang memungkinkan untuk menambahkan beberapa dokumentasi ke penyedia. Kami juga telah menentukan perintah yang akan digunakan penyedia ini. Di baris berikutnya, kami memeriksa fitur sumber daya seperti membuat, menghapus, dan ada.

Menciptakan Sumber Daya

Setelah semua hal di atas selesai, kami akan membuat sumber daya yang akan digunakan di kelas kami dan file manifes seperti yang ditunjukkan pada kode berikut.

repo { "wp": 
   source => "http://g01063908.git.brcl.org/trunk/", 
   path => "/var/www/wp", 
   ensure => present, 
}