524 iocage template ansible_init (hostname)
Use case
Create iocage template ansible_init. Configure firstboot service ansible_init that
runs ansible-pull and uses the repo ansible-conf-init. Configure the repo ansible-conf-init
to pull the jails’ configuration from the repo ansible-conf-test. Create jails from the
template. Use the hostname to select the configuration. Run ansible-pull asynchronously.
Tree
shell > tree .
.
├── ansible.cfg
├── files
│ └── pkgs.json
├── group_vars
│ └── all
│ ├── hosts.yml
│ └── project.yml
├── hosts
│ └── 05_iocage.yml
├── host_vars
│ └── iocage_05
│ └── template.yml
├── iocage.ini
└── pb-iocage-template.yml
Synopsis
At a managed node:
Use the role vbotka.freebsd.iocage_template to create the template
ansible_initIn the playbook vbotka.freebsd.pb_iocage_project_create_from_templates.yml create jails from the template.
Wait for
ansible-pullto configure the jails and display the test files.
Requirements
Note
See the option
firstboot_sentinelin man rc.confSee the example 523 iocage template ansible_repos
See the
Troubleshootingsection in 526 Log server and clients (ansible_init)
ansible.cfg
[defaults]
callback_result_format = yaml
deprecation_warnings = false
display_skipped_hosts = false
gathering = explicit
interpreter_python = auto_silent
log_path = /var/log/ansible.log
[connection]
pipelining = true
Inventory iocage.ini
iocage_05
[iocage]
iocage_05
[iocage:vars]
ansible_user=admin
ansible_become=true
ansible_python_interpreter=auto_silent
hosts
plugin: vbotka.freebsd.iocage
host: iocage_05
user: admin
sudo: true
get_properties: true
compose:
iocage_tags: dict(iocage_properties.notes | regex_findall('(\w+)=([\w\-]+)'))
iocage_classes: iocage_properties.notes | regex_findall('(?<=class=)[\w\-]+|(?<=,)[\w\-]+')
# connection plugin vbotka.freebsd.jailexec
ansible_connection: "'vbotka.freebsd.jailexec'"
ansible_jail_host: dict(iocage_properties.notes | regex_findall('(\w+)=([\w\-]+)')).vmm | d('none')
ansible_jail_name: iocage_jid
ansible_jail_privilege_escalation: "'sudo'"
# ansible options
ansible_python_interpreter: "'auto_silent'"
groups:
pull_init: iocage_classes is contains('init')
pull_test: iocage_classes is contains('test')
keyed_groups:
- prefix: state
key: iocage_state
- prefix: vmm
key: iocage_tags.vmm
group_vars
project_hosts:
defaultrouter: 172.16.99.1
log_server: 172.16.99.10
repos: 172.16.99.21
repos_devel: 172.16.99.22
project:
foo:
class: [test]
template: ansible_init
vmm: iocage_05
bar:
class: [test]
template: ansible_init
vmm: iocage_05
properties:
bpf: 1
dhcp: 1
vnet: 1
boot: 1
vmm_groups: "{{ dict(project | dict2items | groupby('value.vmm')) }}"
vmm: "{{ dict(vmm_groups.keys() | zip(vmm_groups.values() | map('items2dict'))) }}"
host_vars
fit_templates:
ansible_init:
release: 15.0-RELEASE
pkglist: /tmp/ansible/ansible_init/pkgs.json
cron: "{{ fit_cron | dict2items }}"
file_lines: "{{ fit_file_lines | dict2items }}"
firstboot: "{{ fit_firstboot | dict2items }}"
rcconf: "{{ fit_rcconf | dict2items }}"
properties:
bpf: 1
dhcp: 1
vnet: 1
notes: class=init
fit_firstboot:
ansible_init:
content: |
#!/bin/sh
#
# PROVIDE: Pull and execute ansible-conf-init
# REQUIRE: FILESYSTEMS NETWORKING
# KEYWORD: firstboot
. /etc/rc.subr
name="ansible_init"
desc="Firstboot ansible-pull"
rcvar="ansible_init_enable"
start_cmd="ansible_init_start"
: ${ansible_init_repo:="ansible-conf-init"}
: ${ansible_init_dest:="/root"}
: ${ansible_init_playbook:="pb-init.yml"}
ansible_init_env="\
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin \
LANG=en_US.UTF-8 \
LC_ALL=en_US.UTF-8"
ansible_init_start() {
echo "Service ansible_init started."
ansible-pull \
-i hosts \
-U ${ansible_init_host}/${ansible_init_repo} \
-d ${ansible_init_dest}/${ansible_init_repo} \
-e "ansible_pull_mode=true" \
${ansible_init_playbook}
}
load_rc_config $name
run_rc_command "$1"
fit_rcconf:
ansible_init_enable: "YES"
ansible_init_host: "git://{{ project_hosts.repos }}"
fit_cron:
/etc/cron.d/at:
- name: Run atrun execution daemon in 1 minute intervals.
minute: '*/1'
hour: '*'
day: '*'
month: '*'
weekday: '*'
user: root
job: /usr/libexec/atrun
exclusive: true
fit_file_lines:
/root/.profile:
LANG: en_US.UTF-8
LC_ALL: en_US.UTF-8
fit_file_options:
/root/.profile:
assignment_operator: '='
owner: root
group: wheel
mode: '0644'
Playbook pb-iocage-template.yml
---
- name: Create iocage templates.
hosts: iocage
roles:
- vbotka.freebsd.iocage_template
Playbook output - Create iocage templates
(env) > ansible-playbook pb-iocage-template.yml -i iocage.ini
PLAY [Create iocage templates.] ************************************************
TASK [vbotka.freebsd.iocage_template : Setup: Get iocage list of templates.] ***
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Setup: Get activated pool.] *************
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Pkglist: Create directories for pkglist files.] ***
ok: [iocage_05] => (item=ansible_init /tmp/ansible/ansible_init)
TASK [vbotka.freebsd.iocage_template : Pkglist: Copy pkglist files.] ***********
ok: [iocage_05] => (item=ansible_init /tmp/ansible/ansible_init/pkgs.json)
TASK [vbotka.freebsd.iocage_template : Create: Get iocage list of jails.] ******
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Create: Create templates.] **************
changed: [iocage_05] => (item=ansible_init 15.0-RELEASE)
TASK [vbotka.freebsd.iocage_template : Start: Get iocage list of jails.] *******
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Start: Start created templates.] ********
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Lines: Configure lines in files.] *******
included: /scratch/collections/ansible_collections/vbotka/freebsd/roles/iocage_template/tasks/fn/file_lines.yml for iocage_05 => (item=ansible_init)
TASK [vbotka.freebsd.iocage_template : Fn/file_lines: Configure lines in files.] ***
changed: [iocage_05] => (item=ansible_init /root/.profile LANG=en_US.UTF-8)
changed: [iocage_05] => (item=ansible_init /root/.profile LC_ALL=en_US.UTF-8)
TASK [vbotka.freebsd.iocage_template : Firstboot: Create scripts.] *************
changed: [iocage_05] => (item=ansible_init ansible_init)
TASK [vbotka.freebsd.iocage_template : Firstboot: Touch /firstboot.] ***********
changed: [iocage_05] => (item=ansible_init)
TASK [vbotka.freebsd.iocage_template : Cron: Configure cron files.] ************
included: /scratch/collections/ansible_collections/vbotka/freebsd/roles/iocage_template/tasks/fn/cron.yml for iocage_05 => (item=ansible_init)
TASK [vbotka.freebsd.iocage_template : Fn/cron: Remove exclusive jobs from cron files.] ***
changed: [iocage_05] => (item=ansible_init /usr/libexec/atrun)
TASK [vbotka.freebsd.iocage_template : Fn/cron: Configure cron files.] *********
changed: [iocage_05] => (item=ansible_init Run atrun execution daemon in 1 minute intervals.)
TASK [vbotka.freebsd.iocage_template : Rcconf: Configure /etc/rc.conf] *********
changed: [iocage_05] => (item=ansible_init ansible_init_enable YES)
changed: [iocage_05] => (item=ansible_init ansible_init_host git://172.16.99.21)
TASK [vbotka.freebsd.iocage_template : Stop: Get iocage list of jails.] ********
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Stop: Stop jails.] **********************
ok: [iocage_05]
TASK [vbotka.freebsd.iocage_template : Template: Set template.] ****************
ok: [iocage_05] => (item=ansible_init)
PLAY RECAP *********************************************************************
iocage_05 : ok=19 changed=7 unreachable=0 failed=0 skipped=29 rescued=0 ignored=0
List templates
shell > ssh admin@iocage_05 sudo iocage list -lt
+------+---------------+------+-------+----------+--------------+--------------------+-----+----------+----------+
| JID | NAME | BOOT | STATE | TYPE | RELEASE | IP4 | IP6 | TEMPLATE | BASEJAIL |
+======+===============+======+=======+==========+==============+====================+=====+==========+==========+
| None | ansible_init | off | down | template | 15.0-RELEASE | DHCP (not running) | - | - | no |
+------+---------------+------+-------+----------+--------------+--------------------+-----+----------+----------+
| None | ansible_repos | off | down | template | 15.0-RELEASE | DHCP (not running) | - | - | no |
+------+---------------+------+-------+----------+--------------+--------------------+-----+----------+----------+
Playbook output - Create project jails from iocage templates
(env) > ansible-playbook vbotka.freebsd.pb_iocage_project_create_from_templates.yml -i iocage.ini -i hosts
PLAY [Create and start project jails from iocage templates.] *******************
TASK [Setup: Get activated pool.] **********************************************
ok: [iocage_05]
TASK [Create jails.] ***********************************************************
ok: [iocage_05] => (item=foo)
ok: [iocage_05] => (item=bar)
TASK [Set properties.] *********************************************************
ok: [iocage_05] => (item=foo)
ok: [iocage_05] => (item=bar)
TASK [Start jails.] ************************************************************
ok: [iocage_05]
PLAY RECAP *********************************************************************
iocage_05 : ok=4 changed=0 unreachable=0 failed=0 skipped=8 rescued=0 ignored=0
List jails
shell > ssh admin@iocage_05 sudo iocage list -l
+-----+-------------+------+-------+------+--------------+-----------------------+-----+---------------+----------+
| JID | NAME | BOOT | STATE | TYPE | RELEASE | IP4 | IP6 | TEMPLATE | BASEJAIL |
+=====+=============+======+=======+======+==============+=======================+=====+===============+==========+
| 17 | bar | on | up | jail | 15.0-RELEASE | epair0b|172.16.99.103 | - | ansible_init | no |
+-----+-------------+------+-------+------+--------------+-----------------------+-----+---------------+----------+
| 16 | foo | on | up | jail | 15.0-RELEASE | epair0b|172.16.99.102 | - | ansible_init | no |
+-----+-------------+------+-------+------+--------------+-----------------------+-----+---------------+----------+
| 12 | repos | on | up | jail | 15.0-RELEASE | vnet0|172.16.99.21/24 | - | ansible_repos | no |
+-----+-------------+------+-------+------+--------------+-----------------------+-----+---------------+----------+
| 13 | repos-devel | on | up | jail | 15.0-RELEASE | vnet0|172.16.99.22/24 | - | ansible_repos | no |
+-----+-------------+------+-------+------+--------------+-----------------------+-----+---------------+----------+
Display the test files
shell > ssh admin@iocage_05 sudo iocage exec foo "cat /tmp/ansible-hello-world.txt"
[ansible-test] Hello world!
shell > ssh admin@iocage_05 sudo iocage exec bar "cat /tmp/ansible-hello-world.txt"
[ansible-test] Hello world!