Puppet - Conf. Lingkungan

Dalam Wayang, semua lingkungan memiliki environment.confmengajukan. File ini dapat mengganti beberapa pengaturan default setiap kali master melayani salah satu node atau semua node yang ditetapkan ke lingkungan tertentu itu.

Lokasi

Di Puppet, untuk semua lingkungan yang ditentukan, file environment.conf terletak di tingkat teratas dari lingkungan asalnya, tepat di sebelah direktur manifes dan modul. Mempertimbangkan sebuah contoh, jika lingkungan Anda ada di direktori default(Vipin/testing/environment), lalu file konfigurasi lingkungan pengujian berada di Vipin/testing/environments/test/environment.conf.

Contoh

# /etc/testingdir/code/environments/test/environment.conf  
# Puppet Enterprise requires $basemodulepath; see note below under modulepath". 
modulepath = site:dist:modules:$basemodulepath  
# Use our custom script to get a git commit for the current state of the code: 
config_version = get_environment_commit.sh

Format

Semua file konfigurasi di Puppet menggunakan format mirip INI yang sama dengan cara yang sama. environment.conffile mengikuti format seperti INI yang sama seperti yang dilakukan orang lain seperti file puppet.conf. Satu-satunya perbedaan antara environment.conf danpuppet.confadalah file environment.conf tidak dapat berisi bagian [main]. Semua pengaturan di file environment.conf harus berada di luar bagian konfigurasi mana pun.

Jalur Relatif dalam Nilai

Sebagian besar pengaturan yang diizinkan menerima jalur file atau daftar jalur sebagai nilainya. Jika salah satu jalur merupakan jalur yang relevan, jalur tersebut dimulai tanpa garis miring atau huruf drive - sebagian besar akan diselesaikan relatif terhadap direktori utama lingkungan tersebut.

Interpolasi dalam Nilai

File pengaturan environment.conf mampu menggunakan nilai-nilai pengaturan lain sebagai variabel. Ada beberapa variabel berguna yang dapat diinterpolasi ke dalam file environment.conf. Berikut adalah daftar beberapa variabel penting -

  • $basemodulepath- Berguna untuk memasukkan direktori dalam pengaturan jalur modul. Pengguna perusahaan boneka biasanya harus menyertakan nilai inimodulepath karena mesin Wayang menggunakan modul di basemodulepath.

  • $environment- Berguna sebagai argumen baris perintah untuk skrip config_version Anda. Anda hanya dapat menginterpolasi variabel ini di pengaturan config_version.

  • $codedir - Berguna untuk mencari file.

Pengaturan yang Diizinkan

Secara default, file Puppet environment.conf hanya diperbolehkan untuk mengganti empat pengaturan dalam konfigurasi seperti yang terdaftar.

  • Modulepath
  • Manifest
  • Config_version
  • Environment_timeout

Modulepath

Ini adalah salah satu pengaturan kunci di file environment.conf. Semua sutradara yang didefinisikan dalam modulepath secara default dimuat oleh Puppet. Ini adalah lokasi jalur dari mana Puppet memuat modulnya. Seseorang perlu mengatur ini secara eksplisit. Jika pengaturan di atas tidak disetel, modulepath default dari setiap lingkungan di Puppet akan menjadi -

<MODULES DIRECTORY FROM ENVIRONMENT>:$basemodulepath

Nyata

Ini digunakan untuk menentukan file manifes utama, yang akan digunakan master Boneka saat boot dan menyusun katalog dari manifes yang ditentukan yang akan digunakan untuk mengonfigurasi lingkungan. Dalam hal ini, kita dapat menentukan satu file, daftar file, atau bahkan direktori yang terdiri dari beberapa file manifes yang perlu dievaluasi dan dikompilasi dalam urutan abjad yang ditentukan.

Seseorang perlu secara eksplisit mendefinisikan pengaturan ini di file environment.conf. Jika tidak, Puppet akan menggunakan direktori manifes default lingkungan sebagai manifes utamanya.

Config_version

Config_version dapat didefinisikan sebagai versi pasti yang digunakan untuk mengidentifikasi katalog dan acara. Saat Puppet mengompilasi file manifes secara default, ia menambahkan versi konfigurasi ke katalog yang dihasilkan serta laporan yang dihasilkan saat master Puppet menerapkan katalog yang ditentukan pada node Puppet. Puppet menjalankan skrip untuk melakukan semua langkah di atas dan menggunakan semua output yang dihasilkan sebagai Config_version.

Batas Waktu Lingkungan

Ini digunakan untuk mendapatkan detail tentang jumlah waktu yang harus digunakan Puppet untuk memuat data untuk lingkungan tertentu. Jika nilai ditentukan dalam file puppet.conf, maka nilai ini akan menggantikan nilai batas waktu default.

Contoh file environment.conf

[master] 
   manifest =  $confdir/environments/$environment/manifests/site.pp 
   modulepath =  $confdir/environments/$environment/modules

Pada kode di atas $confdir adalah jalur direktori, tempat file konfigurasi lingkungan berada. $environment adalah nama lingkungan tempat konfigurasi dilakukan.

File konfigurasi lingkungan Siap Produksi

# The environment configuration file  
# The main manifest directory or file where Puppet starts to evaluate code  
# This is the default value. Works with just a site.pp file or any other  
manifest = manifests/  
# The directories added to the module path, looked in first match first used order:  
# modules - Directory for external modules, populated by r10k based on Puppetfile  
# $basemodulepath - As from: puppet config print basemodulepath  
modulepath = site:modules:$basemodulepath  
# Set the cache timeout for this environment.  
# This overrides what is set directly in puppet.conf for the whole Puppet server  
# environment_timeout = unlimited  
# With caching you need to flush the cache whenever new Puppet code is deployed  
# This can also be done manually running: bin/puppet_flush_environment_cache.sh  
# To disable catalog caching:  
environment_timeout = 0  
# Here we pass to one in the control repo the Puppet environment (and git branch)  
# to get title and essential info of the last git commit
config_version = 'bin/config_script.sh $environment'