Kukla - Tür ve Sağlayıcı

Kukla türleri, bireysel konfigürasyon yönetimi için kullanılır. Puppet'in hizmet türü, paket türü, sağlayıcı türü gibi farklı türleri vardır. Her türün sağlayıcıları vardır. Sağlayıcı, yapılandırmayı farklı platformlarda veya araçlarda yönetir. Örneğin, paket türünün yetenek, yum, rpm ve DGM sağlayıcıları vardır. Pek çok tür vardır ve Puppet, yönetilmesi gereken iyi bir spektrum yapılandırma yönetimi öğesini kapsar.

Puppet, Ruby'yi temel dil olarak kullanır. Mevcut tüm Kukla türleri ve sağlayıcılar Ruby dilinde yazılmıştır. Standart kodlama formatını takip ettiği için, depoları yöneten depo örneğinde gösterildiği gibi kolayca oluşturulabilir. Burada, tip deposu ve sağlayıcıların svn ve gitlerini oluşturacağız. Repo türünün ilk kısmı, yazının kendisidir. Türler genellikle lib / puppet / type olarak saklanır. Bunun için adlı bir dosya oluşturacağızrepo.rb.

$ touch repo.rb

Aşağıdaki içeriği dosyaya ekleyin.

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

Yukarıdaki komut dosyasında bir blok oluşturduk "Puppet::Type.newtype(:repo) do"Bu, repo adıyla yeni bir tür oluşturur. Ardından, eklemek istediği ayrıntı düzeylerini eklemeye yardımcı olan @doc'a sahibiz. Bir sonraki ifade Ensurable'dır; temel bir sure özelliği oluşturur. Kukla türü kullanır ensure yapılandırma öğesinin durumunu belirlemek için özellik.

Misal

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

Garantiye alma ifadesi Puppet'a üç yöntem dışında şunu söyler: yaratma, yok etme ve sağlayıcıda var olma. Bu yöntemler aşağıdaki özellikleri sağlar -

  • Bir kaynak yaratma komutu
  • Bir kaynağı silme komutu
  • Bir kaynağın varlığını kontrol etme komutu

O zaman tek yapmamız gereken bu yöntemleri ve içeriklerini belirtmektir. Puppet, etrafındaki destek altyapısını oluşturur.

Ardından, source adında yeni bir parametre tanımlıyoruz.

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

Kaynak, depo türüne kaynak deponun nereden alınacağını / klonlanacağını / kullanıma alınacağını söyleyecektir. Bunda ayrıca validate adlı bir kanca kullanıyoruz. Sağlayıcı bölümünde, tanımladığımız deponun geçerliliğini kontrol eden git ve svn tanımladık.

Son olarak, kodda yol adında bir parametre daha tanımladık.

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

Bu, alınan yeni kodun nereye yerleştirileceğini belirten değer türüdür. Burada, uygunluğun değerini kontrol eden bir blok oluşturmak için tekrar validate kancasını kullanın.

Subversion Sağlayıcı Kullanım Örneği

Yukarıda oluşturulan türü kullanarak subversion sağlayıcısıyla başlayalım.

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

Yukarıdaki kodda, ihtiyacımız olduğunu önceden tanımladık fileutils kütüphane, gerekli 'fileutils' yöntemini kullanacağımız.

Daha sonra, sağlayıcıyı block Puppet :: Type.type (: repo) .provide (: svn) do olarak tanımladık ve Puppet'a bunun repo adlı tür için sağlayıcı olduğunu söyler.

Sonra ekledik descbu, sağlayıcıya bazı belgeler eklemenize izin verir. Bu sağlayıcının kullanacağı komutu da tanımladık. Sonraki satırda, kaynak oluşturma, silme ve var olma gibi özellikleri kontrol ediyoruz.

Kaynak Oluşturma

Yukarıdakilerin tümü yapıldıktan sonra, aşağıdaki kodda gösterildiği gibi sınıflarımızda ve manifest dosyalarımızda kullanılacak bir kaynak oluşturacağız.

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