Wayang - Modul

Dalam Puppet, modul dapat didefinisikan sebagai kumpulan sumber daya, kelas, file, definisi, dan templat. Puppet mendukung pendistribusian ulang modul yang mudah, yang sangat membantu dalam modularitas kode karena seseorang dapat menulis modul generik yang ditentukan dan dapat menggunakannya beberapa kali dengan sedikit perubahan kode sederhana. Misalnya, ini akan mengaktifkan konfigurasi situs default di / etc / puppet, dengan modul yang dikirimkan oleh Puppet tepat di / etc / share / puppet.

Konfigurasi Modul

Dalam modul Puppet, kami memiliki dua partisi yang membantu dalam mendefinisikan struktur kode dan mengontrol denominasi.

  • Jalur pencarian modul dikonfigurasi menggunakan daftar direktori yang dipisahkan oleh titik dua di puppetmasterd atau masterd, bagian selanjutnya dari file konfigurasi utama Puppet dengan modulepath parameter.

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

    Jalur pencarian dapat ditambahkan saat runtime dengan menyetel variabel lingkungan PUPPETLAB yang juga harus berupa daftar variabel yang dipisahkan titik dua.

  • Pengaturan kontrol akses untuk modul server file di fileserver.conf, konfigurasi jalur untuk modul itu selalu diabaikan, dan menentukan jalur akan menghasilkan peringatan.

Sumber Modul

Wayang mendukung lokasi berbeda untuk menyimpan modul. Modul apa pun dapat disimpan dalam sistem file berbeda dari mesin tertentu. Namun, semua jalur tempat modul disimpan harus ditentukan dalam variabel konfigurasi yang disebutmodulepath yang secara umum, variabel jalur tempat Puppet memindai semua direktori modul dan memuatnya saat boot.

Jalur default yang wajar dapat dikonfigurasi sebagai -

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

Sebagai alternatif, direktori / etc / puppet dapat dibuat sebagai modul anonim khusus, yang selalu dicari terlebih dahulu.

Penamaan Modul

Puppet mengikuti standar penamaan yang sama dari modul tertentu di mana nama modul harus berupa kata-kata normal, cocok dengan [- \\ w +] (huruf, kata, angka, garis bawah, dan tanda hubung) dan tidak berisi pemisah namespace:: atau /. Meskipun mungkin diperbolehkan terkait hierarki modul, untuk modul baru, ini tidak dapat disarangkan.

Modul Organisasi Internal

Saat pengguna membuat modul baru di Puppet, ia mengikuti struktur yang sama dan berisi manifes, file terdistribusi, plugin, dan template yang disusun dalam struktur direktori tertentu seperti yang ditunjukkan pada kode berikut.

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

Setiap kali modul dibuat, itu berisi init.ppfile manifes di lokasi perbaikan yang ditentukan di dalam direktori manifes. File manifes ini adalah file default yang dijalankan pertama kali dalam modul tertentu dan berisi kumpulan semua kelas yang terkait dengan modul tersebut. Tambahan.ppfile dapat ditambahkan langsung di bawah folder manifests. Jika kita menambahkan file .pp tambahan, mereka harus dinamai sesuai kelas.

Salah satu fitur utama yang dicapai dengan menggunakan modul adalah berbagi kode. Sebuah modul secara alami harus mandiri yang berarti seseorang harus dapat menyertakan modul apa pun dari mana saja dan menjatuhkannya ke jalur modul, yang dimuat saat Puppet melakukan booting. Dengan bantuan modul, seseorang mendapatkan modularitas dalam pengkodean infrastruktur Wayang.

Contoh

Pertimbangkan modul autofs yang menginstal peta auto.homes tetap dan menghasilkan auto.master dari template.

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

Sistem file akan memiliki file-file berikut.

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

Pencarian Modul

Puppet mengikuti struktur yang telah ditentukan sebelumnya yang berisi beberapa direktori dan subdirektori dalam struktur yang ditentukan. Direktori ini berisi berbagai jenis file yang diperlukan oleh modul untuk melakukan tindakan tertentu. Sedikit keajaiban di balik layar memastikan bahwa file yang tepat dikaitkan dengan konteks yang benar. Semua pencarian modul berada dalam modulepath, daftar direktori yang dipisahkan oleh titik dua.

Untuk referensi file pada server file, referensi serupa digunakan sehingga referensi ke puppet: //$servername/modules/autofs/auto.homes menyelesaikan file autofs / files / auto.homes di jalur modul.

Untuk membuat modul bisa digunakan dengan klien baris perintah dan master boneka, kita bisa menggunakan URL dari puppet: /// path. yaitu URL tanpa nama server yang eksplisit. URL tersebut diperlakukan sedikit berbeda olehPuppet dan puppetd. Puppet mencari URL tanpa server dalam sistem file lokal.

File template dicari dengan cara yang mirip dengan manifest dan file: penyebutan template ("autofs / auto.master.erb") akan membuat puppetmaster pertama kali mencari file di $templatedir/autofs/auto.master.erb lalu autofs/templates/auto.master.erbdi jalur modul. Dengan versi Wayang dari segala sesuatu di bawah Wayang, itu tersedia untuk digunakan. Ini disebut pemuatan otomatis modul. Puppet akan mencoba memuat kelas dan definisi secara otomatis dari modul.