Ansible: Difference between revisions

From Chorke Wiki
Jump to navigation Jump to search
 
(51 intermediate revisions by the same user not shown)
Line 1: Line 1:
<source lang="bash">
<syntaxhighlight lang="bash">
sudo apt update  && sudo apt list  --upgradeable
sudo apt update  && sudo apt list  --upgradeable
sudo apt upgrade && sudo apt install ansible
sudo apt upgrade && sudo apt install ansible ansible-lint sshpass
 
sshpass -V
ansible --version
ansible --version
</source>
ansible-lint --version
</syntaxhighlight>


== Playbook ==
== Playbook ==
{|
| valign="top" colspan="2" |
  chorke-academia-project
  chorke-academia-project
  ├─ main_playbook.yml
  ├─ main_playbook.yml
Line 11: Line 16:
     ├─ staging/
     ├─ staging/
     │  └─ academia/
     │  └─ academia/
     │    ├─ group_vars/
     │    ├─ inventory.yml
     │    │  ├─ all.yaml
     │    └─ group_vars/
     │     │  └─ academia_group.yaml
     │       ├─ academia_group.yaml
     │     └─ inventory.yml
     │       └─ all.yaml
     └─ test/
     └─ test/
       └─ academia/
       └─ academia/
           ├─ group_vars/
           ├─ inventory.yml
          │  ├─ all.yaml
          └─ group_vars/
          │   └─ academia_group.yaml
              ├─ academia_group.yaml
           └─ inventory.yml
              └─ all.yaml
 
| valign="top" |
<syntaxhighlight lang="properties">
all:
   children:
    gtw_servers:
      hosts:
        10.20.30.1:
    dmz_servers:
      hosts:
        10.20.30.100:
    dns_servers:
      hosts:
        10.20.30.[100:102]:
      vars:
        ansible_port: 4321
        ansible_user: deploy
        ansible_ssh_pass: sadaqah
</syntaxhighlight>
 
|-
| colspan="3" |
----
|-
| valign="top" colspan="3" |
<syntaxhighlight lang="bash">
mkdir -p chorke-academia-project/inventories/{staging,test}/academia/{group_vars,host_vars}
touch    chorke-academia-project/inventories/{staging,test}/academia/group_vars/{all,academia_group}.yaml
touch    chorke-academia-project/inventories/{staging,test}/academia/inventory.yml
touch    chorke-academia-project/main_playbook.yml
 
cd chorke-academia-project
ansible-playbook  -i inventories/staging main_playbook.yml
ansible-inventory -i inventories/staging --list
</syntaxhighlight>
|}
 
== Playbook » LXD==
{|
|valign="top"|
<syntaxhighlight lang="yaml" highlight="4,12,36,39-43,65-67" line>
mkdir -p ~/Documents/ansible-playground
cd      ~/Documents/ansible-playground
 
cat << 'YML' | tee ./lxd-launch-ubuntu-24-lts.yml >/dev/null
---
- name: LXD Launch Ubuntu 24.04 LTS
  hosts: localhost
  connection: local
  vars:
    cpu_architecture: "{{ ansible_architecture }}"
    os_family: "{{ ansible_os_family }}"
    container_name: ubuntu-24-lts
 
  tasks:
    - name: Dirty Facts
      set_fact:
        raw_cpu_family: >
          {% if ansible_architecture == 'x86_64' %}
            amd64
          {% elif ansible_architecture == 'aarch64' %}
            arm64
           {% else %}
            {{ ansible_architecture }}
          {% endif %}
      delegate_to: localhost
 
    - name: Clean Facts
      set_fact:
        cpu_family: "{{ raw_cpu_family | trim }}"
      delegate_to: localhost
 
    - name: Launch Container
      community.general.lxd_container:
        name: "{{ container_name }}"
        ignore_volatile_options: true
        type: container
        state: started
        source:
          mode: pull
          type: image
          protocol: simplestreams
          server: https://cloud-images.ubuntu.com/releases
          alias: 24.04/{{ cpu_family }}
        profiles: ["default"]
        wait_for_ipv4_addresses: true
        timeout: 600
 
    - name: Check Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- dpkg -s python3.11
      register: python_install_check
      failed_when: python_install_check.rc not in [0, 1]
      changed_when: false
 
    - name: Install Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- apt-get update
        lxc exec {{ container_name }} -- apt-get install -y python3.11
        lxc exec {{ container_name }} -- apt-get clean
      when: python_install_check.rc == 1
YML
 
ansible-playbook lxd-launch-ubuntu-24-lts.yml
lxc exec ubuntu-24-lts -- bash
lxc rm  ubuntu-24-lts -f
lxc ls
</syntaxhighlight>
 
|valign="top"|
<syntaxhighlight lang="yaml" highlight="4,12,36,39-43,65-67" line>
mkdir -p ~/Documents/ansible-playground
cd      ~/Documents/ansible-playground
 
cat << 'YML' | tee ./lxd-launch-ubuntu-24-lts-vm.yml >/dev/null
---
- name: LXD Launch Ubuntu 24.04 LTS
  hosts: localhost
  connection: local
  vars:
    cpu_architecture: "{{ ansible_architecture }}"
    os_family: "{{ ansible_os_family }}"
    container_name: ubuntu-24-lts-vm
 
  tasks:
    - name: Dirty Facts
      set_fact:
        raw_cpu_family: >
          {% if ansible_architecture == 'x86_64' %}
            amd64
          {% elif ansible_architecture == 'aarch64' %}
            arm64
          {% else %}
            {{ ansible_architecture }}
          {% endif %}
      delegate_to: localhost
 
    - name: Clean Facts
      set_fact:
        cpu_family: "{{ raw_cpu_family | trim }}"
      delegate_to: localhost
 
    - name: Launch Container
      community.general.lxd_container:
        name: "{{ container_name }}"
        ignore_volatile_options: true
        type: virtual-machine
        state: started
        source:
          mode: pull
          type: image
          protocol: simplestreams
          server: https://cloud-images.ubuntu.com/releases
          alias: 24.04/{{ cpu_family }}
        profiles: ["default"]
        wait_for_ipv4_addresses: true
        timeout: 600
 
    - name: Check Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- dpkg -s python3.11
      register: python_install_check
      failed_when: python_install_check.rc not in [0, 1]
      changed_when: false
 
    - name: Install Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- apt-get update
        lxc exec {{ container_name }} -- apt-get install -y python3.11
        lxc exec {{ container_name }} -- apt-get clean
      when: python_install_check.rc == 1
YML
 
ansible-playbook lxd-launch-ubuntu-24-lts-vm.yml
lxc exec ubuntu-24-lts-vm -- bash
lxc rm  ubuntu-24-lts-vm -f
lxc ls
</syntaxhighlight>
|}
 
== Molecule ==
mkdir molecule-example && cd molecule-example
python3 -m venv .venv --prompt="molecule"
source ./.venv/bin/activate
pip install 'molecule[lint]'
pip install  molecule-podman
pip freeze  > requirements.txt
molecule init role 'acme.mywebapp' --driver-name podman


== Modules ==
== Modules ==
Line 77: Line 275:
| valign="top" |
| valign="top" |
* [https://docs.ansible.com/ansible/latest/collections/community/general/yarn_module.html <code>community.general.yarn</code>]
* [https://docs.ansible.com/ansible/latest/collections/community/general/yarn_module.html <code>community.general.yarn</code>]
| valign="top" |
| valign="top" |
|-
| colspan="3" |
----
|-
| valign="top" |
* [https://docs.ansible.com/ansible/latest/collections/community/docker/docker_config_module.html <code>community.docker.docker_config</code>]
* [https://docs.ansible.com/ansible/latest/collections/community/docker/docker_image_module.html <code>community.docker.docker_image</code>]
* [https://docs.ansible.com/ansible/latest/collections/community/docker/ <code>Community.Docker</code>]


| valign="top" |
| valign="top" |
Line 181: Line 392:
{|
{|
| valign="top" |
| valign="top" |
<source lang="bash">
<syntaxhighlight lang="bash">
python3 -m venv .venv --prompt="academia"
python3 -m venv .venv --prompt="Molecule"
# source .venv/bin/activate
# source .venv/bin/activate
# (academia) $
# (Molecule) $
</source>
</syntaxhighlight>


| valign="top" |
| valign="top" |
<source lang="bash">
<syntaxhighlight lang="bash">
python3 -m venv .venv --prompt="molecule"
python3 -m venv .venv --prompt="Molecule"
# source .venv/bin/activate
# source .venv/bin/activate
# (molecule) $
# (Molecule) $
</source>
</syntaxhighlight>


| valign="top" |
| valign="top" |
<source lang="PowerShell">
<syntaxhighlight lang="PowerShell">
python -m venv .venv --prompt="molecule"
python -m venv .venv --prompt="Molecule"
# .venv\Scripts\activate
# .venv\Scripts\activate
# (molecule) PS>
# (Molecule) PS>
</source>
</syntaxhighlight>


|-
|-
Line 205: Line 416:
----
----
|-
|-
| valign="top" colspan="3" |
| valign="top" |
<source lang="bash">
<syntaxhighlight lang="bash">
pip install -r requirements.txt
pip install -r requirements.txt
pip freeze  > requirements.txt
pip freeze  > requirements.txt
</source>
</syntaxhighlight>
 
| valign="top" |
<syntaxhighlight lang="ini">
[all:vars]
ansible_port=22
</syntaxhighlight>
 
| valign="ini" |
<syntaxhighlight lang="bash">
ansible_connection=ssh
ansible_ssh_pass=vagrant
</syntaxhighlight>


|-
|-
Line 216: Line 439:
|-
|-
| valign="top"|
| valign="top"|
<source lang="bash">
<syntaxhighlight lang="bash">
ansible-inventory -i inventory --list
ansible-inventory\
</source>
-i inventories/staging/\
--list
</syntaxhighlight>


| valign="top"|
| valign="top"|
<source lang="bash">
<syntaxhighlight lang="bash">
ansible all -i inventory -m ping
ansible dns_servers\
</source>
-i inventories/staging/\
-m ping
</syntaxhighlight>


| valign="top"|
| valign="top"|
<source lang="bash">
<syntaxhighlight lang="bash">
ansible-playbook -i inventory playbook.yml
ansible-playbook\
</source>
-i inventories/staging/\
main_playbook.yml
</syntaxhighlight>
 
|-
| colspan="3" |
----
|-
| valign="top" |
pip install -U pip
pip install --upgrade pip
 
| valign="bottom" |
pip freeze  > requirements.txt
pip install -r requirements.txt --upgrade
 
| valign="bottom" |
pip list --outdated
pip install pip-check
 
|-
| colspan="3" |
----
|-
| colspan="3" |
pip list -o        | gawk -F ' ' 'NR>2{print$1}' | xargs pip install -U
pip list --outdated | gawk -F ' ' 'NR>2{print$1}' | xargs pip install --upgrade


|}
|}
Line 252: Line 505:
* [https://molecule.readthedocs.io/en/latest/getting-started.html Ansible » Test » Molecule » Getting Started]
* [https://molecule.readthedocs.io/en/latest/getting-started.html Ansible » Test » Molecule » Getting Started]
* [https://molecule.readthedocs.io/en/latest/ci.html Ansible » Test » Molecule » CI/CD]
* [https://molecule.readthedocs.io/en/latest/ci.html Ansible » Test » Molecule » CI/CD]
* [https://www.cherryservers.com/blog/how-to-set-up-ansible-inventory-file Ansible » Set Up Inventory File]
* [https://marketplace.visualstudio.com/items?itemName=redhat.ansible Ansible » VS Code Extension]
* [https://www.digitalocean.com/community/tutorials/how-to-set-up-ansible-inventories Ansible » Set Up Inventories]
* [https://www.digitalocean.com/community/tutorials/how-to-set-up-ansible-inventories Ansible » Set Up Inventories]
* [https://spacelift.io/blog/ansible-variables Ansible » Types of Variables]
* [https://spacelift.io/blog/ansible-variables Ansible » Types of Variables]
* [https://docs.ansible.com/ansible-tower/latest/html/userguide/ Ansible » Tower]


| valign="top" |
| valign="top" |
* [https://serverfault.com/questions/628989/ Ansible » Set Default User/Password for SSH]
* [https://stackoverflow.com/questions/37004686/ Ansible » Prompt User/Password from CLI]


|-
|-
Line 265: Line 523:
* [https://stackoverflow.com/questions/62209131/ Dependency File in Python]
* [https://stackoverflow.com/questions/62209131/ Dependency File in Python]
* [[VS Code on iPad Pro]]
* [[VS Code on iPad Pro]]
* [https://docs.fileformat.com/programming/yaml/ What is a YAML File]
* [https://docs.fileformat.com/programming/yml/ What is a YML File]
* [[Docker Compose]]
* [[Docker Compose]]
* [[Linux Containers]]
* [[Linux Containers]]
Line 272: Line 532:


| valign="top" |
| valign="top" |
* [[Academia JavaEE Workspace in Raspbian]]
* [[Academia JavaEE Workspace in Ubuntu]]
* [[Academia JavaEE Workspace in MacOS]]
* [https://dev.to/aws-builders/ssh-setup-and-tunneling-via-bastion-host-3kcc AWS » Bastion Host SSH Tunneling]
* [[Sed Replace A Multi-Line String]]
* [https://serverfault.com/questions/283129/ SSH Connection Hang Forever]
* [https://pip.pypa.io/en/stable/cli/pip_freeze/ Python Pip Freeze]
* [[Terraform]]
* [[OpenVPN]]
* [[Vagrant]]


| valign="top" |
| valign="top" |
* [https://www.activestate.com/resources/quick-reads/how-to-update-all-python-packages/ Update All Python Packages]


|}
|}

Latest revision as of 07:54, 19 May 2024

sudo apt update  && sudo apt list  --upgradeable
sudo apt upgrade && sudo apt install ansible ansible-lint sshpass

sshpass -V
ansible --version
ansible-lint --version

Playbook

chorke-academia-project
├─ main_playbook.yml
└─ inventories/
   ├─ staging/
   │  └─ academia/
   │     ├─ inventory.yml
   │     └─ group_vars/
   │        ├─ academia_group.yaml
   │        └─ all.yaml
   └─ test/
      └─ academia/
         ├─ inventory.yml
         └─ group_vars/
             ├─ academia_group.yaml
             └─ all.yaml
all:
  children:
    gtw_servers:
      hosts:
        10.20.30.1:
    dmz_servers:
      hosts:
        10.20.30.100:
    dns_servers:
      hosts:
        10.20.30.[100:102]:
      vars:
        ansible_port: 4321
        ansible_user: deploy
        ansible_ssh_pass: sadaqah

mkdir -p chorke-academia-project/inventories/{staging,test}/academia/{group_vars,host_vars}
touch    chorke-academia-project/inventories/{staging,test}/academia/group_vars/{all,academia_group}.yaml
touch    chorke-academia-project/inventories/{staging,test}/academia/inventory.yml
touch    chorke-academia-project/main_playbook.yml

cd chorke-academia-project
ansible-playbook  -i inventories/staging main_playbook.yml
ansible-inventory -i inventories/staging --list

Playbook » LXD

mkdir -p ~/Documents/ansible-playground
cd       ~/Documents/ansible-playground

cat << 'YML' | tee ./lxd-launch-ubuntu-24-lts.yml >/dev/null
---
- name: LXD Launch Ubuntu 24.04 LTS
  hosts: localhost
  connection: local
  vars:
    cpu_architecture: "{{ ansible_architecture }}"
    os_family: "{{ ansible_os_family }}"
    container_name: ubuntu-24-lts

  tasks:
    - name: Dirty Facts
      set_fact:
        raw_cpu_family: >
          {% if ansible_architecture == 'x86_64' %}
            amd64
          {% elif ansible_architecture == 'aarch64' %}
            arm64
          {% else %}
            {{ ansible_architecture }}
          {% endif %}
      delegate_to: localhost

    - name: Clean Facts
      set_fact:
        cpu_family: "{{ raw_cpu_family | trim }}"
      delegate_to: localhost

    - name: Launch Container
      community.general.lxd_container:
        name: "{{ container_name }}"
        ignore_volatile_options: true
        type: container
        state: started
        source:
          mode: pull
          type: image
          protocol: simplestreams
          server: https://cloud-images.ubuntu.com/releases
          alias: 24.04/{{ cpu_family }}
        profiles: ["default"]
        wait_for_ipv4_addresses: true
        timeout: 600

    - name: Check Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- dpkg -s python3.11
      register: python_install_check
      failed_when: python_install_check.rc not in [0, 1]
      changed_when: false

    - name: Install Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- apt-get update
        lxc exec {{ container_name }} -- apt-get install -y python3.11
        lxc exec {{ container_name }} -- apt-get clean
      when: python_install_check.rc == 1
YML

ansible-playbook lxd-launch-ubuntu-24-lts.yml
lxc exec ubuntu-24-lts -- bash
lxc rm   ubuntu-24-lts -f
lxc ls
mkdir -p ~/Documents/ansible-playground
cd       ~/Documents/ansible-playground

cat << 'YML' | tee ./lxd-launch-ubuntu-24-lts-vm.yml >/dev/null
---
- name: LXD Launch Ubuntu 24.04 LTS
  hosts: localhost
  connection: local
  vars:
    cpu_architecture: "{{ ansible_architecture }}"
    os_family: "{{ ansible_os_family }}"
    container_name: ubuntu-24-lts-vm

  tasks:
    - name: Dirty Facts
      set_fact:
        raw_cpu_family: >
          {% if ansible_architecture == 'x86_64' %}
            amd64
          {% elif ansible_architecture == 'aarch64' %}
            arm64
          {% else %}
            {{ ansible_architecture }}
          {% endif %}
      delegate_to: localhost

    - name: Clean Facts
      set_fact:
        cpu_family: "{{ raw_cpu_family | trim }}"
      delegate_to: localhost

    - name: Launch Container
      community.general.lxd_container:
        name: "{{ container_name }}"
        ignore_volatile_options: true
        type: virtual-machine
        state: started
        source:
          mode: pull
          type: image
          protocol: simplestreams
          server: https://cloud-images.ubuntu.com/releases
          alias: 24.04/{{ cpu_family }}
        profiles: ["default"]
        wait_for_ipv4_addresses: true
        timeout: 600

    - name: Check Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- dpkg -s python3.11
      register: python_install_check
      failed_when: python_install_check.rc not in [0, 1]
      changed_when: false

    - name: Install Python
      delegate_to: "{{ container_name }}"
      ansible.builtin.raw: |
        lxc exec {{ container_name }} -- apt-get update
        lxc exec {{ container_name }} -- apt-get install -y python3.11
        lxc exec {{ container_name }} -- apt-get clean
      when: python_install_check.rc == 1
YML

ansible-playbook lxd-launch-ubuntu-24-lts-vm.yml
lxc exec ubuntu-24-lts-vm -- bash
lxc rm   ubuntu-24-lts-vm -f
lxc ls

Molecule

mkdir molecule-example && cd molecule-example
python3 -m venv .venv --prompt="molecule"
source ./.venv/bin/activate

pip install 'molecule[lint]'
pip install  molecule-podman
pip freeze   > requirements.txt
molecule init role 'acme.mywebapp' --driver-name podman

Modules






Namespaces


Knowledge

python3 -m venv .venv --prompt="Molecule"
# source .venv/bin/activate
# (Molecule) $
python3 -m venv .venv --prompt="Molecule"
# source .venv/bin/activate
# (Molecule) $
python -m venv .venv --prompt="Molecule"
# .venv\Scripts\activate
# (Molecule) PS>

pip install -r requirements.txt
pip freeze   > requirements.txt
[all:vars]
ansible_port=22
ansible_connection=ssh
ansible_ssh_pass=vagrant

ansible-inventory\
 -i inventories/staging/\
 --list
ansible dns_servers\
 -i inventories/staging/\
 -m ping
ansible-playbook\
 -i inventories/staging/\
 main_playbook.yml

pip install -U pip
pip install --upgrade pip
pip freeze   > requirements.txt
pip install -r requirements.txt --upgrade
pip list --outdated
pip install pip-check

pip list -o         | gawk -F ' ' 'NR>2{print$1}' | xargs pip install -U
pip list --outdated | gawk -F ' ' 'NR>2{print$1}' | xargs pip install --upgrade

References