Výukový program pro začátečníky - Možné příručky, proměnné a zásoby

Beginner S Tutorial Ansible Playbooks



Ansible playbooks jsou soubory, které obsahují úkoly, které jsou spuštěny za účelem konfigurace hostitelů pomocí Ansible. Možné příručky jsou psány ve formátu YAML. YAML je velmi jednoduchý formát souboru stejně jako JSON. Jak bude hrací sešit Ansible YAML vypadat, vám ukážu v pozdější části tohoto článku.

Soubory Ansible Inventory udržují seznam hostitelů, které chcete konfigurovat nebo spravovat pomocí Ansible. Tyto hostitele můžete seskupit a spravovat je také podle skupin. Můžete také předat různé proměnné pro každého hostitele nebo pro skupinu hostitelů.







V tomto článku vám ukážu, jak pracovat s herními sešity Ansible, proměnnými, soubory inventáře a některými běžnými moduly Ansible s praktickými příklady. Pojďme tedy začít!



Předpoklady

Pokud byste chtěli vyzkoušet příklady v tomto článku,



1) Na svém počítači musíte mít nainstalován Ansible.
2) Pro Ansible automation musíte mít nakonfigurovaného alespoň hostitele Ubuntu/Debian a hostitele CentOS/RHEL 8.





Existuje mnoho článků o LinuxHint věnovaných instalaci Ansible a konfiguraci hostitelů pro automatizaci Ansible. V případě potřeby můžete tyto články zkontrolovat a získat další informace.

Vytvoření adresáře projektu

Nejprve vytvořte adresář projektu ~/projekt/ s následujícím příkazem:

$mkdir -pv~/projekt/hrací sešity

Přejděte na ~/projekt/ adresář takto:

$CD~/projekt

Základní inventární soubor:

Vytvořte soubor Ansible inventáře hostitelé v adresáři projektu s následujícím příkazem:

$nanohostitelé

Do pole .Můžete zadat IP adresy hostitelů, které chcete konfigurovat/automatizovat hostitelé inventární soubor.

192,168,20,167
192.168.20.168
192,168,20,169
192,168,20,170

Jakmile tento krok dokončíte, uložte soubor stisknutím + X následován A a .

Chcete -li v inventářním souboru místo IP adres používat názvy DNS, můžete to také provést.

Pokud nemáte funkční server DNS, můžete použít /etc/hosts soubor ve vašem počítači pro místní rozlišení DNS.

Pro místní rozlišení DNS otevřete /etc/hosts soubor s textovým editorem ( nano , v mém případě) takto:

$sudo nano /atd/hostitelé

Zadejte IP adresy a požadované názvy DNS následujícím způsobem:

192.168.20.167 vm1.nodekite.com
192.168.20.168 vm2.nodekite.com
192.168.20.169 vm3.nodekite.com
192.168.20.170 vm4.nodekite.com

Jakmile jste s tímto krokem hotovi, stiskněte + X následován A a .

Otevřete soubor Možný inventář hostitelé jak následuje:

$nanohostitelé

Nyní můžete zadat DNS názvy hostitelů, které chcete konfigurovat/automatizovat pomocí Ansible v hostitelé inventární soubor.

vm1.nodekite.com
vm2.nodekite.com
vm3.nodekite.com
vm4.nodekite.com

Jakmile budete hotovi, uložte soubor inventáře hostitelů stisknutím + X následován A a .

Testování připojení ke všem hostitelům

Nyní se můžete pokusit pingovat všechny hostitele v souboru inventáře následujícím způsobem:

$odpovědný-ihostí všechny-uodpovědný-m ping

Jak vidíte, všichni hostitelé v souboru inventáře jsou dosažitelní. Jsme tedy připraveni přejít k další části tohoto článku.

Vaše první možná příručka

Pojďme vytvořit jednoduchou příručku Ansible ping_all_hosts.yaml v herní knihy/ adresář. Tato akce pingne všem hostitelům v hostitelé inventární soubor, jako dříve.

$nanohrací sešity/ping_all_hosts.yaml

Do řádku zadejte následující řádky ping_all_hosts.yaml Možný soubor playbooku:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- jméno: Pingujte všechny hostitele
ping:

Tady,

hostitelé: všichni - vybere všechny hostitele ze souboru inventáře hostitelé .
uživatel: odpovědný - říká Ansible to SSH do hostitelů v inventárním souboru jako odpovědný uživatel.
úkoly - jsou zde uvedeny všechny úkoly, které bude Ansible provádět v hostitelích. Každý z úkolů má obvykle a název a jedna nebo více možností specifických pro modul.

Playbook ping_all_hosts.yaml má pouze jeden úkol, pinguje všechny hostitele v souboru inventáře hostitelé . Název úkolu je Pingujte všechny hostitele a používá ping modul.

The ping modul nepotřebuje žádné další možnosti. Nechal jsem to tedy prázdné (za dvojtečkou nic není, : )

Jakmile tento krok dokončíte, uložte soubor stisknutím + X následován A a .

Můžete spustit ping_all_hosts.yaml Možný playbook následovně:

$ansible-playbook-ije hostitelem herních sešitů/ping_all_hosts.yaml

Jak vidíte, úloha ping je úspěšná u všech hostitelů v souboru inventáře.

Jednoduchý možný konfigurační soubor

V předchozím příkladu jste museli použít -i možnost sdělit společnosti Ansible, který soubor inventáře použít. V mém případě je to hostitelé inventární soubor.

$ansible-playbook-ije hostitelem herních sešitů/ping_all_hosts.yaml

Pokud si nepřejete předat inventární soubor s příponou -i možnost pokaždé, když spustíte playlist Ansible, stačí nastavit výchozí soubor inventáře pro váš projekt.

Chcete -li to provést, vytvořte nový konfigurační soubor Ansible ansible.cfg v kořenovém adresáři projektu takto:

$nanoansible.cfg

Do řádku zadejte následující řádky ansible.cfg soubor:

[výchozí]
inventář =./hostitelé

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Stejnou příručku hry Ansible můžete spustit následujícím způsobem:

$hratelné příručky pro ansible-playbook/ping_all_hosts.yaml

Jak vidíte, příručka používá hostitelé inventární soubor ve výchozím nastavení. Stále můžete používat -i možnost zadat jiný soubor inventáře, pokud si přejete. Ansible je velmi flexibilní.

Seskupení hostitelů do souboru inventáře

Zatím jsem vám ukázal, jak spustit sadu úkolů (playbook) na všech hostitelích v inventárním souboru. Ale co když chcete spustit sadu úkolů v některých hostitelích a jinou sadu úkolů v jiných hostitelích? Hostitele můžete seskupit do souboru inventáře a ve skupinách hostitelů spouštět různé úkoly.

V této části vám ukážu, jak seskupit hostitele do inventárního souboru a jak pracovat se skupinami hostitelů.

Nejprve otevřete soubor inventáře hostitelé jak následuje:

$nanohostitelé

Do řádku zadejte následující řádky hostitelé inventární soubor:

[debian10]
vm1.nodekite.com
vm2.nodekite.com
[centos8]
vm3.nodekite.com
vm4.nodekite.com

Zde jsem vytvořil dvě hostitelské skupiny: debian10 a centos8 .

V debian10 skupina, mám dva hostitele: vm1.nodekite.com a vm2.nodekite.com

V centos8 skupina, mám dva hostitele: vm3.nodekite.com a vm4.nodekite.com

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Nyní vytvoříme nový playbook ping_debian10_hosts.yaml , který bude ping hostitele jako dříve, ale pouze hostitelé v debian10 hostitelská skupina.

Vytvořte si příručku ping_debian10_hosts.yaml v herní knihy/ adresář takto:

$nanohrací sešity/ping_debian10_hosts.yaml

Do řádku zadejte následující řádky ping_debian10_hosts.yaml Možný playbook:

- hostitelé: debian10
uživatel: odpovědný
úkoly:
- název: Ping all Debian10hostitelé
ping:

Namísto hostitelé: všichni , Přidal jsem hostitelé: debian10 tady. debian10 je hostitelská skupina. Tato příručka poběží pouze na hostitelích v debian10 hostitelská skupina.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte playbook následujícím způsobem:

$hratelné příručky pro ansible-playbook/ping_debian10_hosts.yaml

Jak vidíte, pouze hostitelé v debian10 hostitelská skupina se pingne.

Stejnou metodou vytvořte další příručku ping_centos8_hosts.yaml jak následuje:

$nanohrací sešity/ping_centos8_hosts.yaml

Do řádku zadejte následující řádky ping_centos8_hosts.yaml Možný playbook:

- hostitelé: centos8
uživatel: odpovědný
úkoly:
- název: Ping all CentOS8hostitelé
ping:

Stejným způsobem jsem přidal hostitelé: centos8 tady. centos8 je hostitelská skupina. Tato příručka poběží pouze na hostitelích v centos8 hostitelská skupina.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte playbook následujícím způsobem:

$hratelné příručky pro ansible-playbook/ping_centos8_hosts.yaml

Jak vidíte, pouze hostitelé v centos8 hostitelská skupina se pingne.

Možné typy proměnných

V Ansible existují různé typy proměnných. Hlavní typy proměnných jsou Proměnné možných faktů a Uživatelem definované proměnné .

Proměnné možných faktů: V závislosti na hostiteli, na kterém Ansible pracuje, generuje Ansible proměnné Ansible fact. Proměnné Možné skutečnosti obsahují informace o hostiteli, jako jsou IP adresy, název hostitele, název domény, datum, čas, proměnné prostředí prostředí a další.

Uživatelem definované proměnné: Jedná se o vlastní proměnné definované uživatelem. Uživatelsky definované proměnné můžete předávat z příkazového řádku nebo pomocí souboru inventáře.

Hlavně uživatelsky definované proměnné jsou dvou typů: Skupinové proměnné a Hostitelské proměnné .

Možná variabilní priorita

Proměnná priorita funkce Ansible je : Proměnné příkazového řádku > Hostitelské proměnné > Skupinové proměnné

Pokud nastavíte stejnou proměnnou jako hostitelská a skupinová proměnná, použije se hostitelská proměnná.

Podobně proměnné, které nastavíte z příkazového řádku při spuštění playbooku, nahradí hostitelské i skupinové proměnné.

Práce s proměnnými možných faktů

V této části vám ukážu, jak pracovat s proměnnými Ansible fact. Pojďme tedy začít!

Můžete uvést všechny proměnné Ansible Facts hostitelů ve vašem hostitelé inventární soubor následovně:

$zodpovědný všem-uodpovědný-mzaložit

Jak vidíte, všechny proměnné Ansible Facts jsou uvedeny ve formátu JSON. Je to velmi dlouhý seznam.

Protože je seznam poměrně dlouhý, můžete jej otevřít pomocí programu pro stránkování, jako je méně jak následuje:

$zodpovědný všem-uodpovědný-mzaložit| méně

Nyní můžete výstup posouvat nahoru, dolů, doleva a doprava podle potřeby.

Můžete také vyhledávat názvy proměnných z pageru. Chcete -li to provést, stiskněte tlačítko / klávesu na klávesnici. Poté zadejte hledaný řetězec ( jméno hostitele v mém případě) a stiskněte .

Jak vidíte, proměnná Ansible fact, která odpovídá hledanému řetězci, je ansible_hostname . Můžete stisknout N. jít na další zápas a P přejít na předchozí zápas z pageru. Takto najdete proměnnou Fakta o možném, kterou potřebujete pro svůj projekt Ansible.

Nyní se podívejme, jak přistupovat k proměnným Fakta možných.

Vytvořte nový playbook print_variable1.yaml jak následuje:

$nanohrací sešity/print_variable1.yaml

Do řádku zadejte následující řádky print_variable1.yaml soubor:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- název: Tiskjméno hostitelevšech hostitelů
ladit:
zpráva:'{{ansible_hostname}}'

Zde jsem přidal jeden úkol Vytiskněte název hostitele všech hostitelů . Tento úkol používá Ansible ladit modul pro tisk zprávy při spuštění playbooku.

zpráva je jediným požadovaným parametrem souboru ladit modul. The zpráva parametr přijímá řetězec v uvozovkách, což je zpráva, která bude vytištěna na konzole.

Tady, {{variable_name}} formát se používá k přístupu k proměnné. V tomto případě, {{ansible_hostname}} slouží k tisku ansible_hostname proměnná každého z hostitelů v inventárním souboru.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Můžete také přistupovat k proměnné Možná fakta jako ansible_facts [název_proměnné] . Takže ansible_hostname proměnná se stane ansible_facts [název hostitele] .

Můžeme přepsat print_variable1.yaml playbook také takto. Dostaneme stejný výstup.

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- název: Tiskjméno hostitelevšech hostitelů
ladit:
zpráva:'{{ansible_facts [' variable_name ']}}'

Spusťte playbook print_variable1.yaml jak následuje:

$hratelné příručky pro ansible-playbook/print_variable1.yaml

Jak vidíte, název hostitele každého z hostitelů v souboru inventáře je vytištěn na konzole.

Nyní vytiskneme výchozí adresu IPv4 každého hostitele spolu s názvem hostitele. Jak vidíte, k výchozí adrese IPv4 hostitele lze přistupovat pomocí adresa majetek ansible_default_ipv4 objekt.

Vytvořte nový playbook print_variable2.yaml jak následuje:

$nanohrací sešity/print_variable2.yaml

Do řádku zadejte následující řádky print_variable2.yaml soubor:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- název: Tiskjméno hostitelevšech hostitelů
ladit:
zpráva:'{{ansible_hostname}} - {{ansible_default_ipv4.address}}'

Tato příručka je stejná jako dříve. Jediným rozdílem je nová proměnná {{ansible_default_ipv4.address}} v zpráva možnost ladit modul.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte print_variable2.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/print_variable2.yaml

Jak vidíte, výchozí adresa IPv4 a název hostitele hostitelů jsou vytištěny na konzole.

Takto tedy pracujete s proměnnými Ansible Facts.

Nastavení uživatelem definovaných proměnných z příkazového řádku:

V této části vám ukážu, jak nastavit uživatelem definované proměnné z příkazového řádku při spuštění Ansible playbooks.

Nejprve si vytvořte nový playbook print_variable3.yaml jak následuje:

$nanohrací sešity/print_variable3.yaml

Do řádku zadejte následující řádky print_variable3.yaml soubor:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- název: Tiskpříkazřádková proměnná
ladit:
zpráva:'Vítejte {{username}}'

Tady jsem použil ladit modul pro vytištění zprávy Vítejte {{username}} . uživatelské jméno je proměnná, která bude nahrazena, když spustíme příručku.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte playbook print_variable3.yaml jak následuje:

$ansible-playbook-A 'username = Bob'hrací sešity/print_variable3.yaml

POZNÁMKA: Tady, -A volba se používá k předání a uživatelské jméno proměnná s hodnotou Bob do playbooku print_variable3.yaml z příkazového řádku.

Jak vidíte, zpráva Vítej Bobe je vytištěno na konzole.

Pojďme nyní zjistit, jak předat více proměnných z příkazového řádku.

Vytvořte nový playbook print_variable4.yaml jak následuje:

$nanohrací sešity/print_variable4.yaml

Do řádku zadejte následující řádky print_variable4.yaml soubor:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- název: Tisk uživatelem definovaných proměnných
ladit:
zpráva:'username = {{username}} http_port = {{http_port}}'

Tato příručka by vám teď měla být velmi známá. Vše, co dělá, je vytisknout 2 proměnné uživatelské jméno a http_port na konzole.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Nyní můžete projít uživatelské jméno a http_port variabilní do playbooku pomocí dvou různých -A možnost následovně:

$ ansible-playbook-A 'username = Bob' -A 'http_port = 8080'
hrací sešity/print_variable4.yaml

Nebo můžete proměnné jednoduše oddělit mezerou následovně:

$ ansible-playbook-A 'username = Bob http_port = 8080'
hrací sešity/print_variable4.yaml

Jak vidíte, uživatelské jméno a http_port proměnné jsou vytištěny na konzole.

Práce s uživatelsky definovanými skupinovými proměnnými

Řekněme, že chcete přidat nějaké proměnné do skupiny hostitelů. Tuto akci lze v Ansible velmi snadno provést.

Nejprve otevřete svůj hostitelé inventární soubor následovně:

$nanohostitelé

Zadejte následující řádky do hostitelé inventární soubor:

[debian10]
vm1.nodekite.com
vm2.nodekite.com
[debian10: vars]
uživatelské jméno = Lily
http_port =4343
[centos8]
vm3.nodekite.com
vm4.nodekite.com
[centos8: vars]
uživatelské jméno = Bob
http_port =7878

Jak vidíte, vytvořil jsem novou sekci [debian10: vars] pro debian10 hostitelská skupina a přidal proměnné ( uživatelské jméno a http_port ) pro debian10 hostitelská skupina.

Stejným způsobem jsem vytvořil novou sekci [centos8: vars] pro centos8 hostitelská skupina a přidal proměnné ( uživatelské jméno a http_port ) pro centos8 hostitelská skupina.

Jakmile skončíte, uložte soubor hostitelé inventární soubor stisknutím + X následován A a .

Spusťte print_variable4.yaml herní knihy takto:

$hratelné příručky pro ansible-playbook/print_variable4.yaml

Jak vidíte, každému hostiteli jsou předávány správné proměnné v závislosti na jejich skupině hostitelů.

Práce s uživatelsky definovanými hostitelskými proměnnými

V této části vám ukážu, jak nastavit proměnné pro konkrétní hostitele v souboru inventáře.

Nejprve otevřete hostitelé inventární soubor následovně:

$nanohostitelé

Chcete -li přidat proměnné ke konkrétnímu hostiteli (řekněme, vm1.nodekite.com ), přidejte mezeru/kartu za název IP/DNS hostitele a zadejte své proměnné, jak ukazuje obrázek níže.

Můžete také přidat více proměnných. Jednoduše oddělte každou proměnnou mezerou.

Jakmile budete hotovi, uložte soubor inventáře stisknutím + X následován A a .

Spusťte print_variable4.yaml herní knihy takto:

$hratelné příručky pro ansible-playbook/print_variable4.yaml

Jak vidíte, proměnné jsou nastaveny pouze pro vm1.nodekite.com hostitel. Ostatní hostitelé mají na ně aplikované skupinové proměnné.

Rychlé generování inventárních souborů s rozsahy

Pokud jsou adresy IP hostitele nebo názvy DNS konzistentní (tj. Mají specifický formát), můžete rozsahy použít k rychlé generaci souborů inventáře Ansible.

V předchozích příkladech jsem použil hostitele vm1.nodekite.com , vm2.nodekite.com , vm3.nodekite.com a vm4.nodekite.com . Místo psaní do 4 řádků jsem mohl jen psát vm [1: 4] .nodekite.com v soupisu inventáře.

Pro experimentování s rozsahy otevřete hostitelé inventární soubor následovně:

$nanohostitelé

Odeberte ze souborů inventáře všechny hostitele a proměnné.

Nyní můžeme vyměnit vm1.nodekite.com a vm2.nodekite.com s vm [1: 2] .nodekite.com pro debian10 hostitelská skupina následovně.

Stejným způsobem můžeme nahradit vm3.nodekite.com a vm4.nodekite.com s vm [3: 4] .nodekite.com pro centos8 hostitelská skupina.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte ping_all_hosts.yaml jak následuje:

$hratelné příručky pro ansible-playbook/ping_all_hosts.yaml

Jak vidíte, rozsahy hostitelů byly rozšířeny, když jsem spustil příručku.

Ukládání proměnných v různých souborech

Uložení skupinových proměnných a hostitelských proměnných do stejného inventárního souboru je velmi snadné. Možná ale hledáte větší flexibilitu. Zvláště pokud chcete v souboru inventáře používat rozsahy, protože při použití rozsahů již nemůžete nastavovat hostitelské proměnné. Skupinové proměnné a hostitelské proměnné můžete ukládat do různých souborů. V této sekci vám ukážu, jak se to dělá.

Ve výchozím nastavení Ansible hledá skupinové proměnné v group_vars / proměnné adresáře a hostitele v souboru host_vars / adresář.

Vytvořte tedy group_vars / a host_vars / adresář takto:

$mkdir -pv {hostitel, skupina}_jehož

Chcete -li nastavit skupinové proměnné pro debian10 hostitelská skupina, vytvořte soubor debian10 (stejné jako název skupiny) v group_vars / adresář takto:

$nanogroup_vars/debian10

Proměnné zadejte následujícím způsobem:

uživatelské jméno: Lily
http_port: 4343

Až budete hotovi, uložte soubor stisknutím + X následuje Y a .

Stejným způsobem lze nastavit skupinové proměnné pro centos8 hostitelská skupina, vytvořte soubor centos8 (stejné jako název skupiny) v group_vars / adresář takto:

$nanogroup_vars/centos8

Proměnné zadejte následujícím způsobem:

uživatelské jméno: Bob
http_port: 7878

Až budete hotovi, uložte soubor stisknutím + X následuje Y a .

Spusťte print_variable4.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/print_variable4.yaml

Jak vidíte, skupinové proměnné jsou správně nastaveny pro každou hostitelskou skupinu.

Nastavení hostitelských proměnných pro hostitele vm1.nodekite.com , vytvořte soubor vm1.nodekite.com (stejné jako název hostitele nebo IP adresa) v host_vars / adresář takto:

$nanovm1.nodekite.com

Proměnné hostitele zadejte následujícím způsobem:

uživatelské jméno: Alex
http_port: 7788

Až budete hotovi, uložte soubor stisknutím + X následuje Y a .

Spusťte print_variable4.yaml hrací kniha takto:

$ ansible-playbook playbooks/print_variable4.yaml
[

Jak vidíte, hostitelské proměnné jsou pro hostitele správně nastaveny vm1.nodekite.com .

Práce se smyčkami v Ansible

V této části vám ukážu, jak používat smyčky v Ansible.

Nejprve si vytvořte nový playbook loop1.yaml v herní knihy/ adresář takto:

$nanohrací sešity/loop1.yaml

Do řádku zadejte následující řádky loop1.yaml hrací kniha:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- jméno: Tisk seznamu uživatelů
ladit:
zpráva:'Uživatel: {{item}}'
with_items:
- Alexi
- Bobu
- Lily

Tady mám 1 úkol, který vytiskne seznam uživatelů pomocí smyčky.

Chcete -li nastavit hodnoty iterace pro úkol, použijte with_items modul. Potom přidáte hodnoty jednu po druhé.

with_items:
- Alexi
- Bobu
- Lily

K hodnotě aktuální iterace přistupujete pomocí položka proměnná.

ladit:
zpráva:'Uživatel: {{item}}'

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte loop1.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/loop1.yaml

Jak vidíte, stejný úkol běžel pro každou položku na každém hostiteli. Smyčka tedy funguje.

Práce s podmínkami v Ansible

Pokud chcete spouštět úkoly na základě určitých podmínek, pak je tato část pro vás.

Ke spouštění úkolů na základě podmínek můžete použít když modul Ansible. Podívejme se na příklad tohoto modulu. Nejprve si vytvořte nový playbook podmínka1.yaml jak následuje:

$nanohrací sešity/podmínka1.yaml

Do řádku zadejte následující řádky podmínka1.yaml hrací kniha:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- name: Spusťte tento úkol pouze na Debianu
ladit:
zpráva:„Tento úkol běží na Debianu“
když: ansible_facts['rozdělení']=='Debian'

Tady,

ansible_facts [‘distribuce‘] == ‘Debian’ slouží ke kontrole, zda rozdělení je Debian . Úkol se spustí pouze v případě, že distribuce je Debian.

The ansible_facts [‘distribuce‘] slouží k přístupu k proměnné Ansible Facts ansible_distribution . Distribuční verzi můžete také zkontrolovat pomocí ansible_distribution_major_version proměnná.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte podmínka1.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/podmínka1.yaml

Jak vidíte, úkol běžel pouze na hostitelích Debianu. Úkol nebyl spuštěn na hostitelích CentOS.

Můžete také zkontrolovat více podmínek současně a spustit úlohu, pouze pokud jsou splněny všechny podmínky. Podívejme se na příklad.

Vytvořte nový playbook podmínka2.yaml jak následuje:

$nanohrací sešity/podmínka2.yaml

Do řádku zadejte následující řádky podmínka2.yaml soubor:

- hostitelé: všichni
uživatel: odpovědný
úkoly:
- name: Spusťte tento úkol pouze na Debianu10
ladit:
zpráva:'Tento úkol běží na Debianu 10'
když: ansible_facts['rozdělení']=='Debian'
a ansible_facts['distribution_major_version']=='10'

Zde se úloha spustí pouze v případě, že distribuce je Debian ( ansible_facts [‘distribuce‘] == ‘Debian’ ) a verze je 10 ( ansible_facts [‘distribution_major_version’] == ‘10’ ). Pokud jsou splněny obě podmínky, úloha se spustí. V opačném případě se úloha nespustí.

Použil jsem a klíčové slovo a zkontrolujte, zda jsou zde splněny obě podmínky. Pokud chcete zkontrolovat, zda je některá z podmínek splněna, můžete použít nebo místo toho klíčové slovo.

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte playbook podmínka2.yaml jak následuje:

$hratelné příručky pro ansible-playbook/podmínka2.yaml

Jak vidíte, úkol běžel pouze na hostitelích Debianu 10.

Pojďme změnit příručku podmínka2.yaml spustit úlohu pouze na hostitelích Debianu 8 následujícím způsobem.

Jak vidíte, všichni hostitelé byli přeskočeni, protože v inventárním souboru nemám žádné hostitele Debianu 8.

Práce s Ansible apt Module

The výstižný modul Ansible slouží k instalaci konkrétního softwarového balíčku na hostitele Ubuntu/Debian. Podívejme se, jak tento modul používat.

Nejprve si vytvořte nový playbook apt1.yaml v herní knihy/ adresář takto:

$nanohrací sešity/apt1.yaml

Do řádku zadejte následující řádky apt1.yaml hrací kniha:

- hostitelé: debian10
uživatel: odpovědný
stát se: Pravda
úkoly:
- název: Nainstalujte apache2
výstižné:
název: apache2
stav: nejnovější

The výstižný modul vyžaduje pouze název balíčku, který chcete nainstalovat/upgradovat/odebrat, a Stát balíčku.

Zde se snažím nainstalovat apache2 balíček ( název: apache2 ) na mých hostitelích Debianu 10. Když se pokouším nainstalovat balíček a také jej upgradovat, pokud je k dispozici nová verze, soubor Stát mělo by nejnovější .

Stát akceptuje také následující možnosti:

- chybí - Balíček bude odstraněn, pokud již je nainstalován.
- nejnovější - Balíček bude upgradován, pokud je k dispozici aktualizace. Pokud balíček ještě není nainstalován, bude nainstalován.
- současnost, dárek - Balíček bude nainstalován, pokud ještě není nainstalován. Pokud je však k dispozici aktualizace, balíček nebude upgradován.

Všimněte si, že jsem přidal stát se: Pravda v playbooku. Tím se získá odpovědný uživatelská oprávnění sudo pro úpravu struktury systému souborů (tj. instalace/upgrade/odebrání balíků). Bez stát se: Pravda , výstižný modul nebude moci nainstalovat apache2 balík.

Až budete hotovi, uložte si playbook stisknutím + X následován A a .

Spusťte apt1.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/apt1.yaml

Jak vidíte, playbook úspěšně běžel na hostitelích Debianu 10.

Jak vidíte, apache2 balíček je nainstalován na mých hostitelích Debianu 10.

Práce s modulem Ansible dnf/yum

The dnf a Mňam modul Ansible slouží k instalaci konkrétního softwarového balíčku na hostitele CentOS/RHEL. Tento modul můžete používat stejným způsobem, jakým jste výstižný modul v dřívější části tohoto článku.

Oba dnf a Mňam moduly přijímají stejné parametry. Můžete použít dnf modul na hostitelích CentOS/RHEL 8 a Mňam na CentOS/RHEL 7 nebo starší.

Podívejme se nyní na příklad tohoto modulu.

Nejprve si vytvořte nový playbook dnf1.yaml v herní knihy/ adresář takto:

$nanohrací sešity/dnf1.yaml

Do řádku zadejte následující řádky dnf1.yaml hrací kniha:

- hostitelé: centos8
uživatel: odpovědný
stát se: Pravda
úkoly:
- název: Nainstalujte balíček httpd
dnf:
jméno: httpd
stav: nejnovější

The dnf a Mňam modul vyžaduje pouze název balíčku, který chcete nainstalovat/upgradovat/odebrat, a Stát balíčku.

Zde se snažím nainstalovat httpd balíček ( jméno: httpd ) na mých hostitelích CentOS 8. Když se pokouším nainstalovat balíček a také bych ho chtěl upgradovat, pokud je k dispozici nová verze, soubor Stát mělo by nejnovější .

Stát přijímá následující možnosti:

- chybí - Balíček bude odstraněn, pokud již je nainstalován.
- nejnovější - Balíček bude upgradován, pokud je k dispozici aktualizace. Pokud balíček ještě není nainstalován, bude nainstalován.
- současnost, dárek - Balíček bude nainstalován, pokud ještě není nainstalován. Pokud je však k dispozici aktualizace, balíček nebude upgradován.

Všimněte si, že jsem přidal stát se: Pravda v playbooku. To dává odpovědný uživatelská oprávnění sudo pro úpravu struktury systému souborů (tj. instalace/upgrade/odebrání balíků). Bez stát se: Pravda , výstižný modul nebude moci nainstalovat httpd balík.

Až budete hotovi, uložte si playbook stisknutím + X následován A a .

Spusťte dnf1.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/dnf1.yaml

Jak vidíte, playbook úspěšně běžel na hostiteli CentOS 8.

Práce s modulem Ansible service

The servis modul Ansible slouží ke spouštění, zastavování, restartování, povolení (přidání služby ke spuštění) a zakázání (odebrání služby při spuštění) služeb ve vašich hostitelích.

V předchozích částech jsem vám ukázal, jak nainstalovat balíček serveru Apache HTTP pomocí nástroje Ansible výstižný , dnf a Mňam moduly. Nyní zajistíme, aby byla spuštěna služba serveru Apache HTTP a byla přidána ke spuštění systému.

Budu pracovat se svými hostiteli Debianu 10. Pokud však chcete, můžete pracovat s hostiteli CentOS 8. Podle toho jednoduše upravte playbook.

Nejprve vytvořte nový playlist Ansible apt2.yaml jak následuje:

$nanohrací sešity/apt2.yaml

Do řádku zadejte následující řádky apt2.yaml hrací kniha:

- hostitelé: debian10
uživatel: odpovědný
stát se: Pravda
úkoly:
- název: Nainstalujte apache2
výstižné:
název: apache2
stav: nejnovější
- název: Spusťte službu apache2
servis:
název: apache2
stav: zahájeno
povoleno: Pravda

Zde jsem přidal nový úkol, Spusťte službu apache2 .

název: apache2 - služba, na které pracuji, je apache2 .

stav: zahájeno - služba musí být spuštěna.

povoleno: Pravda - služba musí být přidána ke spuštění systému.

The Stát parametr přijímá jiné hodnoty.

- Re loaded - Služba musí znovu načíst konfigurační soubory.
- restartován - Služba musí být restartována.
- začal - Služba musí být spuštěna. Pokud služba není spuštěna, spusťte ji.
- zastavil - Služba musí být zastavena. Pokud je služba spuštěná, zastavte ji.

Spusťte playbook apt2.yaml jak následuje:

$hratelné příručky pro ansible-playbook/apt2.yaml

Jak vidíte, příručka proběhla úspěšně.

Jak vidíte, apache2 služba běží na mých hostitelích Debianu 10.

Práce s modulem Ansible Copy

The Ansible kopírovat modul se používá hlavně ke kopírování souborů z vašeho počítače na vzdálené počítače.

V předchozí části jsem nainstaloval webový server Apache 2 na své hostitele Debianu 10. Zkopírujme nyní index.html soubor do webového kořene hostitelů Debianu 10.

Nejprve vytvořte nový adresář soubory/ jak následuje:

$mkdir -protisoubory

Vytvořte nový soubor index.html v soubory/ adresář takto:

$nanosoubory/index.html

Do řádku zadejte následující řádky index.html soubor:


< html >
< hlava >
< titul >Webserver od Ansible</ titul >
</ hlava >
< tělo >
< h1 >Vítejte v LinuxHintu</ h1 >
< p >Tento webový server byl nasazen s Ansible.</ p >
</ tělo >
</ html >

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Vytvořte novou příručku Ansible apt3.yaml jak následuje:

$nanohrací sešity/apt3.yaml

Do řádku zadejte následující řádky apt3.yaml soubor:

- hostitelé: debian10
uživatel: odpovědný
stát se: Pravda
úkoly:
- název: Nainstalujte apache2
výstižné:
název: apache2
stav: nejnovější
- název: Zkopírujte index.html na server
kopírovat:
src: ../soubory/index.html
dest:/kde/www/html/index.html
režim: 0644
vlastník: www-data
skupina: www-data
- název: Spusťte službu apache2
servis:
název: apache2
stav: zahájeno
povoleno: Pravda

Tady je úkol Zkopírujte index.html na server zkopíruje soubor index.html z soubory/ adresář do / var / www / html / adresář hostitelů Debianu 10.

src: ../files/index.html - Cesta ke zdrojovému souboru.
dest: /var/www/html/index.html - Cesta k cílovému souboru.
režim: 0644 - Oprávnění pro uživatele souboru (6 - čtení a zápis), skupinu (4 - čtení) a další (4 - čtení).
vlastník: www-data - Nastavte vlastníka souboru na www-data .
skupina: www-data - Nastavte skupinu souboru na www-data .

Až budete hotovi, uložte soubor stisknutím + X následován A a .

Spusťte apt3.yaml hrací kniha takto:

$hratelné příručky pro ansible-playbook/apt3.yaml

Jak vidíte, úkol Zkopírujte index.html na server je úspěšný.

Jak vidíte, index.html soubor byl zkopírován do hostitelů Debianu 10.

Jak vidíte, webový server Debian 10 slouží index.html stránku, kterou jsem právě zkopíroval na hostitele Debianu 10.

To jsou tedy základy hry Ansible. Můžete se dozvědět více o Ansible čtením oficiální dokumentace Ansible. Děkujeme za přečtení tohoto článku.