Puppet - Memvalidasi Puppet Setup
Di Puppet, penyiapan dapat diuji secara lokal. Oleh karena itu, setelah kita menyiapkan master Puppet dan node, inilah waktunya untuk memvalidasi pengaturan secara lokal. Kita perlu memiliki kotak Vagrant dan Vagrant yang diinstal secara lokal, yang membantu dalam menguji pengaturan secara lokal.
Menyiapkan Mesin Virtual
Karena kami menguji penyiapan secara lokal, kami sebenarnya tidak memerlukan master Puppet yang sedang berjalan. Ini berarti tanpa benar-benar menjalankan Puppet master di server, kita cukup menggunakan Puppet untuk menerapkan perintah untuk validasi setup Puppet. Perintah penerapan boneka akan menerapkan perubahan darilocal/etc/puppet tergantung pada nama host mesin virtual di file konfigurasi.
Langkah pertama yang perlu kita lakukan untuk menguji pengaturan adalah membangun berikut ini Vagrantfile dan mulai mesin dan pasang /etc/puppetfolder ke tempatnya. Semua file yang diperlukan akan ditempatkan di dalam sistem kontrol versi dengan struktur sebagai berikut.
Struktur Direktori
- manifests
\- site.pp
- modules
\- your modules
- test
\- update-puppet.sh
\- Vagrantfile
- puppet.conf
File Gelandangan
# -*- mode: ruby -*-
# vi: set ft = ruby :
Vagrant.configure("2") do |config|
config.vm.box = "precise32"
config.vm.box_url = "http://files.vagrantup.com/precise64.box"
config.vm.provider :virtualbox do |vb|
vb.customize ["modifyvm", :id, "--memory", 1028, "--cpus", 2]
end
# Mount our repo onto /etc/puppet
config.vm.synced_folder "../", "/etc/puppet"
# Run our Puppet shell script
config.vm.provision "shell" do |s|
s.path = "update-puppet.sh"
end
config.vm.hostname = "localdev.example.com"
end
Dalam kode di atas, kami telah menggunakan penyedia Shell di mana kami mencoba menjalankan skrip Shell bernama update-puppet.sh. Skrip ada di direktori yang sama di mana file Vagrant berada dan konten skrip tercantum di bawah ini.
!/bin/bash
echo "Puppet version is $(puppet --version)"
if [ $( puppet --version) != "3.4.1" ]; then
echo "Updating puppet"
apt-get install --yes lsb-release
DISTRIB_CODENAME = $(lsb_release --codename --short)
DEB = "puppetlabs-release-${DISTRIB_CODENAME}.deb"
DEB_PROVIDES="/etc/apt/sources.list.d/puppetlabs.list"
if [ ! -e $DEB_PROVIDES ]
then
wget -q http://apt.puppetlabs.com/$DEB
sudo dpkg -i $DEB
fi
sudo apt-get update
sudo apt-get install -o Dpkg::Options:: = "--force-confold"
--force-yes -y puppet
else
echo "Puppet is up to date!"
fi
Pemrosesan lebih lanjut, pengguna perlu membuat file manifes di dalam direktori Manifes dengan nama site.pp yang akan menginstal beberapa perangkat lunak di VM.
node 'brclelocal03.brcl.com' {
package { ['vim','git'] :
ensure => latest
}
}
echo "Running puppet"
sudo puppet apply /etc/puppet/manifests/site.pp
Setelah pengguna memiliki skrip di atas siap dengan konfigurasi file Vagrant yang diperlukan, pengguna dapat cd ke direktori pengujian dan menjalankan vagrant up command. Ini akan mem-boot VM baru, Nanti, instal Puppet dan kemudian jalankan menggunakan skrip Shell.
Berikut akan menjadi keluarannya.
Notice: Compiled catalog for localdev.example.com in environment production in 0.09 seconds
Notice: /Stage[main]/Main/Node[brclelocal03.brcl.com]/Package[git]/ensure: created
Notice: /Stage[main]/Main/Node[brcllocal03.brcl.com]/Package[vim]/ensure: ensure changed 'purged' to 'latest'
Memvalidasi Konfigurasi Beberapa Mesin
Jika kita perlu menguji konfigurasi beberapa mesin secara lokal, itu dapat dilakukan dengan membuat perubahan pada file konfigurasi Vagrant.
File Vagrant yang Dikonfigurasi Baru
config.vm.define "brclelocal003" do |brclelocal003|
brclelocal03.vm.hostname = "brclelocal003.brcl.com"
end
config.vm.define "production" do |production|
production.vm.hostname = "brcleprod004.brcl.com"
end
Mari kita asumsikan kita memiliki server produksi baru, yang membutuhkan utilitas SSL terpasang. Kita hanya perlu memperluas manifes lama dengan konfigurasi berikut.
node 'brcleprod004.brcl.com' inherits 'brcleloacl003.brcl.com' {
package { ['SSL'] :
ensure => latest
}
}
Setelah melakukan perubahan konfigurasi pada file manifes, kita hanya perlu pindah ke direktori tes dan menjalankan perintah dasar vagrant up yang akan memunculkan keduanya brclelocal003.brcl.com dan brcleprod004.brcl.commesin. Dalam kasus kami, kami mencoba memunculkan mesin produksi yang dapat dilakukan dengan menjalankanvagrant up production command. Itu akan membuat mesin baru dengan nama produksi seperti yang didefinisikan dalam file Vagrant dan itu akan memiliki paket SSL diinstal di dalamnya.