Puppet - moduł

W Puppet moduł można zdefiniować jako zbiór zasobów, klas, plików, definicji i szablonów. Puppet obsługuje łatwą redystrybucję modułów, co jest bardzo pomocne w modularności kodu, ponieważ można napisać określony moduł ogólny i używać go wiele razy z bardzo niewielką liczbą prostych zmian w kodzie. Na przykład, włączy to domyślną konfigurację witryny w / etc / puppet, z modułami dostarczanymi przez Puppet w / etc / share / puppet.

Konfiguracja modułu

W każdym module Puppet mamy dwie partycje, które pomagają w definiowaniu struktury kodu i kontrolowaniu nominałów.

  • Ścieżka wyszukiwania modułów jest konfigurowana przy użyciu rozdzielanej dwukropkami listy katalogów w puppetmasterd lub masterd, późniejsza sekcja głównego pliku konfiguracyjnego Puppet z rozszerzeniem modulepath parametr.

[puppetmasterd] 
... 
modulepath = /var/lib/puppet/modules:/data/puppet/modules

    Ścieżkę wyszukiwania można dodać w czasie wykonywania, ustawiając zmienną środowiskową PUPPETLAB, która musi być również listą zmiennych oddzielonych dwukropkami.

  • Ustawienia kontroli dostępu do modułów serwera plików w plikach fileserver.conf, konfiguracja ścieżki dla tego modułu jest zawsze ignorowana, a określenie ścieżki spowoduje wyświetlenie ostrzeżenia.

Źródło modułów

Puppet obsługuje inną lokalizację do przechowywania modułów. Każdy moduł może być przechowywany w innym systemie plików na dowolnej maszynie. Jednak wszystkie ścieżki, w których przechowywane są moduły, muszą być określone w zmiennej konfiguracyjnej znanej jakomodulepath czyli ogólnie zmienna ścieżki, w której Puppet wyszukuje wszystkie katalogi modułów i ładuje je podczas uruchamiania.

Rozsądną ścieżkę domyślną można skonfigurować jako -

/etc/puppet/modules:/usr/share/puppet:/var/lib/modules.

Alternatywnie, katalog / etc / puppet mógłby zostać utworzony jako specjalny moduł anonimowy, który jest zawsze przeszukiwany jako pierwszy.

Nazewnictwo modułów

Puppet stosuje te same standardy nazewnictwa określonego modułu, w których nazwa modułu musi być zwykłymi słowami, pasującymi do [- \\ w +] (litera, słowo, cyfra, podkreślenie i myślniki) i nie zawierającą separatora przestrzeni nazw:: lub /. Chociaż może to być dozwolone w odniesieniu do hierarchii modułów, w przypadku nowych modułów nie można go zagnieżdżać.

Moduł Organizacja wewnętrzna

Kiedy użytkownik tworzy nowy moduł w Puppet, ma tę samą strukturę i zawiera manifest, rozproszony plik, wtyczki i szablony ułożone w określonej strukturze katalogów, jak pokazano w poniższym kodzie.

MODULE_PATH/ 
   downcased_module_name/ 
      files/ 
      manifests/ 
         init.pp 
      lib/ 
         puppet/ 
            parser/ 
               functions 
            provider/ 
            type/ 
         facter/ 
      templates/ 
      README

Za każdym razem, gdy tworzony jest moduł, zawiera init.ppplik manifestu w określonej lokalizacji poprawki w katalogu manifestów. Ten plik manifestu jest plikiem domyślnym, który jest wykonywany jako pierwszy w danym module i zawiera kolekcję wszystkich klas powiązanych z tym konkretnym modułem. Dodatkowy.ppplik można dodać bezpośrednio w folderze manifestów. Jeśli dodajemy dodatkowe pliki .pp, należy je nazwać zgodnie z klasą.

Jedną z kluczowych funkcji uzyskanych dzięki zastosowaniu modułów jest współdzielenie kodu. Moduł z natury powinien być samowystarczalny, co oznacza, że ​​można dołączyć dowolny moduł z dowolnego miejsca i upuścić go na ścieżkę modułu, która jest ładowana po uruchomieniu Puppet. Z pomocą modułów uzyskuje się modułowość w kodowaniu infrastruktury Puppet.

Przykład

Rozważmy moduł autofs, który instaluje stałą mapę auto.homes i generuje auto.master z szablonów.

class autofs { 
   package { autofs: ensure => latest } 
   service { autofs: ensure => running } 
   
   file { "/etc/auto.homes": 
      source => "puppet://$servername/modules/autofs/auto.homes" 
   } 
   file { "/etc/auto.master": 
      content => template("autofs/auto.master.erb") 
   } 
}

System plików będzie zawierał następujące pliki.

MODULE_PATH/ 
autofs/ 
manifests/ 
init.pp 
files/ 
auto.homes 
templates/ 
auto.master.erb

Wyszukiwanie modułu

Puppet podąża za predefiniowaną strukturą, w której zawiera wiele katalogów i podkatalogów w zdefiniowanej strukturze. Te katalogi zawierają różnego rodzaju pliki, które są wymagane przez moduł do wykonywania określonych czynności. Odrobina zakulisowej magii sprawia, że ​​właściwy plik jest powiązany z odpowiednim kontekstem. Wszystkie wyszukiwania modułów znajdują się w modulepath, rozdzielonej dwukropkami liście katalogów.

W przypadku odniesień do plików na serwerze plików używane jest podobne odniesienie, dzięki czemu odniesienie do puppet: //$servername/modules/autofs/auto.homes jest tłumaczone na plik autofs / files / auto.homes w ścieżce modułu.

Aby moduł działał zarówno z klientem wiersza poleceń, jak i mistrzem marionetek, można użyć adresu URL ścieżki from puppet: ///. tj. adres URL bez wyraźnej nazwy serwera. Taki adres URL jest traktowany nieco inaczej przezPuppet i puppetd. Puppet szuka bezserwerowego adresu URL w lokalnym systemie plików.

Pliki szablonów są przeszukiwane w sposób podobny do manifestu i plików: wzmianka o szablonie („autofs / auto.master.erb”) spowoduje, że puppetmaster najpierw poszuka pliku w $templatedir/autofs/auto.master.erb i wtedy autofs/templates/auto.master.erbna ścieżce modułu. Wszystkie wersje Puppet są dostępne do użycia. Nazywa się to automatycznym ładowaniem modułów. Puppet podejmie próbę automatycznego załadowania klas i definicji z modułu.