Puppet - Instalasi dan Konfigurasi r10K

Di Puppet, kami memiliki alat manajemen kode yang dikenal sebagai r10k yang membantu dalam mengelola konfigurasi lingkungan yang terkait dengan berbagai jenis lingkungan yang dapat kami konfigurasikan di Puppet seperti pengembangan, pengujian, dan produksi. Ini membantu dalam menyimpan konfigurasi terkait lingkungan di repositori kode sumber. Dengan menggunakan cabang repo kontrol sumber, r10k membuat lingkungan pada instalasi mesin master Puppet dan memperbarui lingkungan menggunakan modul yang ada di repo.

File permata dapat digunakan untuk menginstal r10k pada mesin apa pun kecuali untuk modularitas dan untuk mendapatkan versi terbaru, kami akan menggunakan pengelola paket rpm dan rpm. Berikut adalah contoh yang sama.

$ urlgrabber -o /etc/yum.repos.d/timhughes-r10k-epel-6.repo
https://copr.fedoraproject.org/coprs/timhughes/yum -y install rubygem-r10k

Konfigurasikan lingkungan di /etc/puppet/puppet.conf

[main] 
environmentpath = $confdir/environments

Buat File Konfigurasi untuk r10k Config

cat <<EOF >/etc/r10k.yaml 
# The location to use for storing cached Git repos 
:cachedir: '/var/cache/r10k' 
# A list of git repositories to create 
:sources: 
# This will clone the git repository and instantiate an environment per 
# branch in /etc/puppet/environments 
:opstree: 
#remote: 'https://github.com/fullstack-puppet/fullstackpuppet-environment.git' 
remote: '/var/lib/git/fullstackpuppet-environment.git' 
basedir: '/etc/puppet/environments' 
EOF

Memasang Modul dan Manifes Wayang

r10k deploy environment -pv

Karena kami perlu terus memperbarui lingkungan setiap 15 menit, kami akan membuat tugas cron untuk hal yang sama.

cat << EOF > /etc/cron.d/r10k.conf 
SHELL = /bin/bash 
PATH = /sbin:/bin:/usr/sbin:/usr/bin 
H/15 * * * * root r10k deploy environment -p 
EOF

Menguji Instalasi

Untuk menguji apakah semuanya bekerja seperti yang diterima, seseorang perlu menyusun manifes Wayang untuk modul Puppet. Jalankan perintah berikut dan dapatkan keluaran YAML sebagai hasilnya.

curl --cert /etc/puppet/ssl/certs/puppet.corp.guest.pem \ 
--key /etc/puppet/ssl/private_keys/puppet.corp.guest.pem \ 
--cacert /etc/puppet/ssl/ca/ca_crt.pem \ 
-H 'Accept: yaml' \ 
https://puppet.corp.guest:8140/production/catalog/puppet.corp.guest