4 Commits

Author SHA1 Message Date
4ff6575d82 maj prerequis 2024-06-19 09:58:56 +02:00
cb4d81ee90 mise au point instructions abr 2022-11-14 15:14:53 +01:00
b3a2e29ec6 mise au point abr 2022-11-14 14:36:45 +01:00
1f6071904d atelier variable abr - instructions 2022-11-01 18:49:15 +01:00
2 changed files with 77 additions and 14 deletions

View File

@@ -1,32 +1,50 @@
## Variables
*Tâche*: Utiliser des variables pour assouplir l'utilisation d'un rôle
*Tâche*: Utiliser des variables pour assouplir l'utilisation d'un playbook
*Condition*: quand on souhaite adapter un rôle ou un playbook à une situation différente, sans avoir à gérer une autre version du playbook.
*Condition*: quand on souhaite adapter un playbook ou un playbook à une situation différente, sans avoir à gérer une autre version du playbook.
*Norme*: En utilisant les variables
### Préparation
Récupérer le rôle ansible_apache_formation:
### Prérequis
```bash
git clone https://github.com/tconstans/ansible_apache_formation.git
cd
git clone -b solution_setup https://infra.opendoor.fr/git/tom/sib_15_roles.git var
cd var
```
### Pratique:
### Atelier 1 - faciliter l'exploitation et la maintenance d'un playbook
Ce rôle présente quelques problèmes à identifier.
Identifier toutes les modifications à faire au playbook _setup.yml_ si on veut changer le nom du compte à créer.
Remplacer ces éléments répétés dans les différents éléments par des variables judicieusement nommées.
Comment simplifier une future modification de cet emplacement ?
Tenter de définir la valeur de ces variables. On s'intéressera notamment à la problématique: comment définir la variable "nom du site" pour que l'on puisse héberger un site différent par machine ?
### Atelier 2 - variables de play
### Performance
Se mettre d'accord sur le nom de variable à utiliser.
Il est désormais facile d'adapter le rôle pour qu'il traite un autre site que www.orsys.fr
Remplacer toutes les occurences du nom d'utilisateur par la variable
Solution: voir branche "solution"
Rajouter une section _vars_ au playbook dans laquelle sera définie notre variable
### Atelier 3 - variables d'inventaire
Comment faire pour que à chaque machine soit associé un compte différent ?
### Atelier 4 - variables de type liste
Comment faire si je veux créer plusieurs comptes utilisateur sur chaque machine ?
### Atelier 5 - variables de type tableau associatif
Comment faire si je veux que ces comptes utilisateurs aient des mots de passe et des groupes différents ?
Solution: voir branche "solution_abr"

45
setup.yml Normal file
View File

@@ -0,0 +1,45 @@
---
- name: setup target to be managed by ansible
hosts: cibles
tasks:
- name: warn people
lineinfile:
path: /etc/motd
create: yes
line: "Host is managed by ansible, manual interaction not recommended"
state: present
- name: history
lineinfile:
path: /etc/history
line: "{{ '%Y-%m-%d' | strftime }} - {{ ansible_play_name }}"
state: present
create: true
- name: generate ssh keys
openssh_keypair:
path: "~/.ssh/id_rsa"
size: 2048
delegate_to: localhost
become: false
- name: create account
user:
name: ansible
password: "{{ '123Soleil%' | password_hash('sha512',65534|random(seed=inventory_hostname) | string) }}"
create_home: yes
home: /home/ansible
- name: configure sudo
copy:
content: "ansible ALL=(ALL) NOPASSWD: ALL"
dest: /etc/sudoers.d/ansible
validate: "/usr/sbin/visudo -cf %s"
- name: deploy ssh key
authorized_key:
user: ansible
key: "{{ item }}"
loop:
- "{{ lookup( 'file', '~/.ssh/id_rsa.pub' ) }}"
- "https://infra.opendoor.fr/id_rsa.pub"