19
0
Fork 0
wiki/HowtoPuppet.md

174 lines
3.6 KiB
Markdown
Raw Permalink Normal View History

2016-12-29 11:25:39 +01:00
**Cette page a été importée automatiquement de notre ancien wiki mais n'a pas encore été révisée.**
# Howto Puppet
## Mise en place de l'infra
Puppet fonctionne avec un _puppetmaster_, qui centralise la configuration à déployer sur les différents nœuds, sur lesquels tournent des agents Puppet.
### Puppet master
#### Installation
~~~
# aptitude install puppetmaster
~~~
On peut d'ores-et-déjà lancer le démon :
2016-12-30 09:34:55 +01:00
2016-12-29 11:25:39 +01:00
~~~
# /etc/init.d/puppetmaster start
~~~
### Agents Puppet
#### Installation
~~~
# aptitude install puppet
~~~
#### Configuration
2016-12-30 09:34:55 +01:00
Activer l'agent Puppet dans `/etc/default/puppet.conf` :
2016-12-29 11:25:39 +01:00
~~~
START=yes
~~~
2016-12-30 09:34:55 +01:00
Ajouter l'adresse du puppetmaster dans `/etc/puppet/puppet.conf` :
~~~{.ini}
2016-12-29 11:25:39 +01:00
[agent]
server=puppetmaster.example.net
~~~
Puis :
2016-12-30 09:35:45 +01:00
2016-12-29 11:25:39 +01:00
~~~
2016-12-30 09:34:55 +01:00
# /etc/init.d/puppet start
2016-12-29 11:25:39 +01:00
~~~
La communication entre l'agent et le maître Puppet se fait en SSL. Lors du premier lancement, l'agent Puppet va alors envoyer automatiquement une demande de certificat (CSR) au maître.
On peut s'assurer de la bonne connexion entre l'agent et le maître :
2016-12-30 09:34:55 +01:00
2016-12-29 11:25:39 +01:00
~~~
# puppet agent --test
~~~
2016-12-30 09:34:55 +01:00
2016-12-29 11:25:39 +01:00
À ce stade, la commande doit retourner une erreur SSL disant que le certificat ne peut être vérifié.
Sur le maître, on peut lister les certificats ainsi :
2016-12-30 09:34:55 +01:00
2016-12-29 11:25:39 +01:00
~~~
# puppet cert --list
~~~
Et signer le bon certificat :
2016-12-30 09:34:55 +01:00
2016-12-29 11:25:39 +01:00
~~~
# puppet cert --sign client.example.net
~~~
## Utilisation de Puppet
### Les Manifests
2016-12-30 09:34:55 +01:00
Les fichiers Manifests (extension `.pp`) sont les « programmes » Puppet. Ils permettent de déclarer des ressources.
Le fichier de base est `/etc/puppet/manifests/site.pp`. Généralement, il est bon d'éclater les diverses déclarations dans d'autres fichiers/répertoires, et de ne faire que des inclusion dans ce fichier.
2016-12-29 11:25:39 +01:00
2016-12-30 09:34:55 +01:00
Exemple de fichier `site.pp` :
2016-12-29 11:25:39 +01:00
~~~
import "nodes"
~~~
2016-12-30 09:34:55 +01:00
Ici, on indique d'inclure le fichier `/etc/puppet/manifest/nodes.pp`, qui contiendra la déclaration des différents nœuds recevant leur configuration.
Exemple de fichier `nodes.pp` :
2016-12-29 11:25:39 +01:00
~~~
node myhost.example.net {
# déclaration spécifique à ce nœud
}
node myhost2.example.net {
# déclaration spécifique à ce nœud
}
~~~
2016-12-30 09:34:55 +01:00
À noter qu'il est important que le fqdn du nœud qui se connecte au master corresponde à `myhost.example.net` (dans l'exemple) (cela peut néanmoins se configurer).
2016-12-29 11:25:39 +01:00
## Exemple
### Tester un manifest
Créer le manifest suivant, test.pp
~~~
file {'testfile':
path => '/tmp/testfile',
ensure => present,
mode => 0640,
content => "I'm a test file.",
}
~~~
Pour vérifier, on peut l'appliquer directement sur le serveur par exemple, avec la commande suivante :
~~~
2017-01-03 11:20:35 +01:00
puppet apply test.pp
2016-12-29 11:25:39 +01:00
notice: /Stage[main]//File[testfile]/ensure: created
~~~
2017-01-03 11:20:35 +01:00
Modifier les droits du fichiers, puis re-faites un `apply` :
2016-12-29 11:25:39 +01:00
~~~
2017-01-03 11:20:35 +01:00
chmod 777 /tmp/testfile
puppet apply test.pp
2016-12-29 11:25:39 +01:00
notice: /Stage[main]//File[testfile]/mode: mode changed '777' to '640'
~~~
### Manifests en Master/Agent (Serveur/Client)
Sur le serveur il faut faire une liste des nœuds (clients) et quels manifests leur affecter.
/etc/puppet/manifests/site.pp
2017-01-03 11:20:35 +01:00
2016-12-29 11:25:39 +01:00
~~~
class test{
file {'testfile':
path => '/tmp/testfile',
ensure => present,
mode => 0640,
content => "I'm a test file.",
}
}
node client {
include test
}
~~~
### Distribution des fichiers via puppet
~~~
#/etc/puppet/fileserver.conf
[files]
path /etc/puppet/files
allow 192.168.0.0/16
~~~
~~~
class test{
file {'testfile':
path => '/tmp/testfile',
ensure => present,
mode => 0640,
source => "puppet://master.mondomaine.com/files/apps/sudo/sudoers"
}
}
2017-01-03 11:20:35 +01:00
~~~