Puppet - funkcje niestandardowe

Jak opisano w poprzednim rozdziale, function zapewnia użytkownikowi przywilej tworzenia własnych funkcji. Puppet może rozszerzyć swoją zdolność interpretacji za pomocą funkcji niestandardowych. Funkcja niestandardowa pomaga w zwiększaniu i rozszerzaniu mocy modułów Puppet i plików manifestu.

Pisanie funkcji niestandardowej

Jest kilka rzeczy, o których należy pamiętać przed napisaniem funkcji.

  • W Puppet funkcje są wykonywane przez kompilatory, co oznacza, że ​​wszystkie funkcje działają w Puppet master i nie muszą zajmować się żadnym klientem Puppet w tym samym. Funkcje mogą wchodzić w interakcje tylko z agentami, pod warunkiem, że informacje mają formę faktów.

  • Mistrz Puppet przechwytuje niestandardowe funkcje, co oznacza, że ​​należy ponownie uruchomić mistrza Puppet, jeśli wprowadzi się pewne zmiany w funkcji Puppet.

  • Funkcja zostanie wykonana na serwerze, co oznacza, że ​​każdy plik, którego potrzebuje funkcja, powinien znajdować się na serwerze i nie można nic zrobić, jeśli funkcja wymaga bezpośredniego dostępu do komputera klienta.

  • Dostępne są zupełnie dwa różne typy funkcji, jedna to funkcja Rvalue, która zwraca wartość, i funkcja instrukcji, która nic nie zwraca.

  • Nazwa pliku zawierającego funkcję powinna być taka sama, jak nazwa funkcji w pliku. W przeciwnym razie nie załaduje się automatycznie.

Lokalizacja do umieszczenia funkcji niestandardowej

Wszystkie funkcje niestandardowe są realizowane jako oddzielne .rbpliki i są dystrybuowane między modułami. W lib / puppet / parser / function należy umieścić własne funkcje. Funkcje można ładować z.rb plik z następujących lokalizacji.

  • $libdir/puppet/parser/functions
  • podkatalogi puppet / parser / functions w twoim Ruby $ LOAD_PATH

Tworzenie nowej funkcji

Nowe funkcje są tworzone lub definiowane za pomocą newfunction metoda wewnątrz puppet::parser::Functionsmoduł. Nazwę funkcji należy przekazać jako symbolnewfunctionmetoda i kod do uruchomienia jako blok. Poniższy przykład to funkcja, która służy do zapisywania ciągu znaków w pliku w katalogu / user.

module Puppet::Parser::Functions 
   newfunction(:write_line_to_file) do |args| 
      filename = args[0] 
      str = args[1] 
      File.open(filename, 'a') {|fd| fd.puts str } 
   end 
end

Gdy użytkownik zadeklaruje funkcję, można jej użyć w pliku manifestu, jak pokazano poniżej.

write_line_to_file('/user/vipin.txt, "Hello vipin!")