In Ansible sind Variablen und Fakten zusammen mit Vorlagen grundlegende Werkzeuge für die Erstellung flexibler Automatisierungsworkflows. Mithilfe von Variablen können Sie Ihre Konfigurationen dynamisch verwalten und ändern. Fakten sind eine spezielle Teilmenge von Variablen, die Ansible von den Remote-Systemen sammelt und kontextspezifische Informationen bereitstellt.
Vorlagen ermöglichen die Generierung von variablengesteuerten Konfigurationsdateien, sodass Ihre Playbooks an unterschiedliche Umgebungen und Szenarien anpassbar sind.
Diese Tools machen Playbooks wiederverwendbar und anpassbar, sodass Sie die harte Codierung von Werten vermeiden und eine Anpassung an verschiedene Umgebungen ermöglichen können.
Mithilfe von Variablen können Parameter geändert werden, ohne die Kernlogik des Playbooks zu ändern.
Boolescher Wert: Wahre oder falsche Werte.
Liste: Eine geordnete Sammlung von Elementen.
Wörterbuch: Schlüssel-Wert-Paare für komplexe Datenstrukturen.
Registrierte Variablen: Erfasst die Ausgabe von Aufgaben zur späteren Verwendung in Ihrem Playbook.
Fakten: Automatisch erfasste Variablen, die Details zu den von Ihnen verwalteten Remote-Systemen liefern.
Hinweis: Vermeiden Sie Konflikte in Variablennamen, indem Sie die Klammernotation verwenden.
- name: Print the distribution of the target hosts: all vars: curr_time: "{{ now() }}" tasks: - name: Distro Check ansible.builtin.debug: msg: "The target system is {{ ansible_facts['distribution'] }}. Timestamp: {{ curr_time }}"
Vorlagen in Ansible verwenden die Vorlagensprache Jinja2, um Dateien mithilfe von Variableninterpolation, Schleifen und Bedingungen dynamisch zu erstellen.
- name: Write distro name hosts: all tasks: - name: Write distro name ansible.builtin.template: src: distro.j2 dest: /root/distro.txt mode: '644' # src: location of jinja2 template file # dest: location it will be copied to # permissions that will be granted to the file
Wir werden die Betriebssystemfamilie verwenden, um zu bestimmen, ob NGINX von Lighttpd installiert werden soll, und dann werden wir eine benutzerdefinierte Homepage auf dem Remote-Host bereitstellen, die NGINX enthält, alles ohne fest codierte Hostnamen.
git clone https://github.com/perplexedyawdie/ansible-learn.git
2. Wechseln Sie in das Verzeichnis „facts-and-templates“.
cd ansible-learn/facts-and-templates
3. Starten Sie die Umgebung mit Docker-Compose
docker compose up -d --build
4. Stellen Sie eine SSH-Verbindung zum Ansible-Server her
ssh -o StrictHostKeyChecking=no -o NoHostAuthenticationForLocalhost=yes root@localhost -p 2200 # password: test123
5. Erstellen Sie ein Playbook mit dem Namen server_setup.yaml
. Hier richten wir NGINX und Lighttpd ein und geben dann den Namen der Distribution für jeden Remote-Host aus.
- name: Install NGINX on Debian & Lighttpd on RedHat hosts: all vars: dev1: "Debian" dev2: "RedHat" tasks: - name: Install NGINX for Debian-based systems ansible.builtin.apt: name: nginx state: present when: ansible_facts['os_family'] == dev1 - name: Install Lighttpd for RedHat-based systems ansible.builtin.yum: name: lighttpd state: present when: ansible_facts['os_family'] == dev2 - name: Display the distribution ansible.builtin.debug: msg: "The server is running {{ ansible_facts['distribution'] }}"
6. Führen Sie ansible-lint.
ansible-lint server_setup.yaml
7. Führen Sie das Playbook aus.
ansible-playbook --key-file /root/.ssh/id_rsa_ansible -u root -i inventory.yaml server_setup.yaml
8. Bestätigen Sie, dass die Einrichtung erfolgreich war.
ssh -i /root/.ssh/id_rsa_ansible root@server3 nginx -V ssh -i /root/.ssh/id_rsa_ansible root@server2 lighttpd -v ssh -i /root/.ssh/id_rsa_ansible root@server1 lighttpd -v
9. Erstellen Sie eine Jinja2-Vorlagendatei mit dem Namen index.html.j2
Es wird automatisch mit der Betriebssystemfamilie und -verteilung ausgefüllt.
<html> <head> <title>Welcome to {{ ansible_facts['os_family'] }}</title> </head> <body> <h1>Server running on {{ ansible_facts['distribution'] }}</h1> </body> </html>
10. Erstellen Sie ein Playbook mit dem Namen custom_homepage.yaml.
Wir stellen die oben erstellte benutzerdefinierte Homepage auf NGINX bereit und starten dann den Server neu.
- name: Deploy Custom Homepage and restart hosts: all vars: dev1: "Debian" dev2: "RedHat" tasks: - name: Create Homepage with Jinja2 Template for NGINX ansible.builtin.template: src: index.html.j2 dest: /var/www/html/index.html mode: '644' when: ansible_facts['os_family'] == dev1 notify: restart nginx handlers: - name: Restart NGINX listen: "restart nginx" ansible.builtin.service: name: nginx state: restarted when: ansible_facts['os_family'] == dev1
11. Lassen Sie den Linter laufen.
ansible-lint custom_homepage.yaml
12. Führen Sie das Playbook aus.
ansible-playbook --key-file /root/.ssh/id_rsa_ansible -u root -i inventory.yaml custom_homepage.yaml
13. Bestätigen Sie die Bereitstellung, indem Sie http://localhost:2203
in Ihrem Browser aufrufen.
Toller Aufwand! 🙌 Wir haben gelernt, wie man Variablen und Fakten in einem Playbook verwendet und wie man mithilfe von Vorlagen dynamische Dateien erstellt. Als nächstes schauen wir uns die Modularisierung und Fehlerbehandlung an. Bis dahin, pass auf dich auf!