d2c9ed3e45
The playbook can now optimize itself based on the enabled components in for all hosts in the inventory (`just optimize`) or for a specific host (`just optimize-for-host HOSTNAME`). The optimized playbook will have: - fewer requirements (fewer roles need to be installed by `just roles`) - a shorter and quicker to evaluate `group_vars/mash_servers` file - a `setup.yml` file which includes less roles Running the playbook optimized is still work in progress. There still probably exist various role dependencies in the group-vars file, etc. The `optimize-reset` command aims to restore your playbook to a non-optimized state, which should work as before (and not experience bugs). The playbook takes care to notice of changes to the various files in `templates/` (`setup.yml`, `requirements.yml`, `group_vars_mash_servers`) and update your optimized or non-optimized copies that are derived from these templates. To do this, it keeps `.srchash` files in the `run/` directory. When it notices a change in the source file's hash (by comparing to the `.srchash` file), it will update you to the new template. Optimization state is stored in a file in `run/` as well (`optimization-vars-files.state`). Should the playbook notice changes in the source `template/` files, it should update you and re-optimize using the same parameters as before (read from the state file).
174 lines
7 KiB
Makefile
174 lines
7 KiB
Makefile
# Shows help
|
|
default:
|
|
@just --list --justfile {{ justfile() }}
|
|
|
|
run_directory_path := justfile_directory() + "/run"
|
|
templates_directory_path := justfile_directory() + "/templates"
|
|
optimization_vars_files_file_path := run_directory_path + "/optimization-vars-files.state"
|
|
|
|
# Pulls external Ansible roles
|
|
roles: _requirements-yml
|
|
#!/usr/bin/env sh
|
|
if [ -x "$(command -v agru)" ]; then
|
|
agru -r {{ justfile_directory() }}/requirements.yml
|
|
else
|
|
rm -rf roles/galaxy
|
|
ansible-galaxy install -r {{ justfile_directory() }}/requirements.yml -p roles/galaxy/ --force
|
|
fi
|
|
|
|
# Optimizes the playbook based on stored configuration (vars.yml paths)
|
|
optimize-restore:
|
|
#!/usr/bin/env sh
|
|
if [ -f "$optimization_vars_files_file_path" ]; then
|
|
just --justfile {{ justfile() }} \
|
|
_optimize-for-var-paths \
|
|
$(cat $optimization_vars_files_file_path)
|
|
else
|
|
echo "Cannot restore optimization state from a file ($optimization_vars_files_file_path), because it doesn't exist"
|
|
exit 1
|
|
fi
|
|
|
|
# Clears optimizations and resets the playbook to a non-optimized state
|
|
optimize-reset: && _clean_template_derived_files
|
|
#!/usr/bin/env sh
|
|
rm -f {{ run_directory_path }}/*.srchash
|
|
rm -f {{ optimization_vars_files_file_path }}
|
|
|
|
# Optimizes the playbook based on the enabled components for all hosts in the inventory
|
|
optimize inventory_path='inventory': _reconfigure-for-all-hosts
|
|
|
|
_reconfigure-for-all-hosts inventory_path='inventory':
|
|
#!/usr/bin/env sh
|
|
just --justfile {{ justfile() }} \
|
|
_optimize-for-var-paths \
|
|
$(find {{ inventory_path }}/host_vars/ -maxdepth 2 -name '*.yml' -exec readlink -f {} \;)
|
|
|
|
# Optimizes the playbook based on the enabled components for a single host
|
|
optimize-for-host hostname inventory_path='inventory':
|
|
#!/usr/bin/env sh
|
|
just --justfile {{ justfile() }} \
|
|
_optimize-for-var-paths \
|
|
$(find {{ inventory_path }}/host_vars/{{ hostname }} -maxdepth 1 -name '*.yml' -exec readlink -f {} \;)
|
|
|
|
# Optimizes the playbook based on the enabled components found in the given vars.yml files
|
|
_optimize-for-var-paths +PATHS:
|
|
#!/usr/bin/env sh
|
|
echo '{{ PATHS }}' > {{ optimization_vars_files_file_path }}
|
|
|
|
just --justfile {{ justfile() }} _save_hash_for_file {{ templates_directory_path }}/requirements.yml {{ justfile_directory() }}/requirements.yml
|
|
just --justfile {{ justfile() }} _save_hash_for_file {{ templates_directory_path }}/setup.yml {{ justfile_directory() }}/setup.yml
|
|
just --justfile {{ justfile() }} _save_hash_for_file {{ templates_directory_path }}/group_vars_mash_servers {{ justfile_directory() }}/group_vars/mash_servers
|
|
|
|
/usr/bin/env python {{ justfile_directory() }}/bin/optimize.py \
|
|
--vars-paths='{{ PATHS }}' \
|
|
--src-requirements-yml-path={{ templates_directory_path }}/requirements.yml \
|
|
--dst-requirements-yml-path={{ justfile_directory() }}/requirements.yml \
|
|
--src-setup-yml-path={{ templates_directory_path }}/setup.yml \
|
|
--dst-setup-yml-path={{ justfile_directory() }}/setup.yml \
|
|
--src-group-vars-yml-path={{ templates_directory_path }}/group_vars_mash_servers \
|
|
--dst-group-vars-yml-path={{ justfile_directory() }}/group_vars/mash_servers
|
|
|
|
# Updates requirements.yml if there are any new tags available. Requires agru
|
|
update: && opml
|
|
@agru -r {{ templates_directory_path }}/requirements.yml -u
|
|
|
|
# Runs ansible-lint against all roles in the playbook
|
|
lint:
|
|
ansible-lint
|
|
|
|
# dumps an OPML file with extracted git feeds for roles
|
|
opml:
|
|
@echo "generating opml..."
|
|
@python bin/feeds.py . dump
|
|
|
|
# Runs the playbook with --tags=install-all,start and optional arguments
|
|
install-all *extra_args: (run-tags "install-all,start" extra_args)
|
|
|
|
# Runs installation tasks for a single service
|
|
install-service service *extra_args:
|
|
just --justfile {{ justfile() }} run \
|
|
--tags=install-{{ service }},start-group \
|
|
--extra-vars=group={{ service }} \
|
|
--extra-vars=devture_systemd_service_manager_service_restart_mode=one-by-one {{ extra_args }}
|
|
|
|
# Runs the playbook with --tags=setup-all,start and optional arguments
|
|
setup-all *extra_args: (run-tags "setup-all,start" extra_args)
|
|
|
|
# Runs the playbook with the given list of arguments
|
|
run +extra_args: _requirements-yml _setup-yml _group-vars-mash-servers
|
|
ansible-playbook -i inventory/hosts setup.yml {{ extra_args }}
|
|
|
|
# Runs the playbook with the given list of comma-separated tags and optional arguments
|
|
run-tags tags *extra_args:
|
|
just --justfile {{ justfile() }} run --tags={{ tags }} {{ extra_args }}
|
|
|
|
# Starts all services
|
|
start-all *extra_args: (run-tags "start-all" extra_args)
|
|
|
|
# Starts a specific service group
|
|
start-group group *extra_args:
|
|
@just --justfile {{ justfile() }} run-tags start-group --extra-vars="group={{ group }}" {{ extra_args }}
|
|
|
|
# Stops all services
|
|
stop-all *extra_args: (run-tags "stop-all" extra_args)
|
|
|
|
# Stops a specific service group
|
|
stop-group group *extra_args:
|
|
@just --justfile {{ justfile() }} run-tags stop-group --extra-vars="group={{ group }}" {{ extra_args }}
|
|
|
|
# Prepares the requirements.yml file
|
|
_requirements-yml:
|
|
@just --justfile {{ justfile() }} _ensure_file_prepared {{ templates_directory_path }}/requirements.yml {{ justfile_directory() }}/requirements.yml
|
|
|
|
# Prepares the setup.yml file
|
|
_setup-yml:
|
|
@just --justfile {{ justfile() }} _ensure_file_prepared {{ templates_directory_path }}/setup.yml {{ justfile_directory() }}/setup.yml
|
|
|
|
# Prepares the group_vars/mash_servers file
|
|
_group-vars-mash-servers:
|
|
@just --justfile {{ justfile() }} _ensure_file_prepared {{ templates_directory_path }}/group_vars_mash_servers {{ justfile_directory() }}/group_vars/mash_servers
|
|
|
|
_ensure_file_prepared src_path dst_path:
|
|
#!/usr/bin/env sh
|
|
dst_file_name=$(basename "{{ dst_path }}")
|
|
hash_path={{ run_directory_path }}"/"$dst_file_name".srchash"
|
|
src_hash=$(md5sum {{ src_path }} | cut -d ' ' -f 1)
|
|
|
|
if [ ! -f "{{ dst_path }}" ] || [ ! -f "$hash_path" ]; then
|
|
cp {{ src_path }} {{ dst_path }}
|
|
echo $src_hash > $hash_path
|
|
else
|
|
current_hash=$(cat $hash_path)
|
|
|
|
if [ "$current_hash" != "$src_hash" ]; then
|
|
cp {{ src_path }} {{ dst_path }}
|
|
echo $src_hash > $hash_path
|
|
|
|
if [ -f "$optimization_vars_files_file_path" ]; then
|
|
just --justfile {{ justfile() }} \
|
|
_optimize-for-var-paths \
|
|
$(cat $optimization_vars_files_file_path)
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
_save_hash_for_file src_path dst_path:
|
|
#!/usr/bin/env sh
|
|
dst_file_name=$(basename "{{ dst_path }}")
|
|
hash_path={{ run_directory_path }}"/"$dst_file_name".srchash"
|
|
src_hash=$(md5sum {{ src_path }} | cut -d ' ' -f 1)
|
|
echo $src_hash > $hash_path
|
|
|
|
_clean_template_derived_files:
|
|
#!/usr/bin/env sh
|
|
if [ -f "{{ justfile_directory() }}/requirements.yml" ]; then
|
|
rm {{ justfile_directory() }}/requirements.yml
|
|
fi
|
|
|
|
if [ -f "{{ justfile_directory() }}/setup.yml" ]; then
|
|
rm {{ justfile_directory() }}/setup.yml
|
|
fi
|
|
|
|
if [ -f "{{ justfile_directory() }}/group_vars/mash_servers" ]; then
|
|
rm {{ justfile_directory() }}/group_vars/mash_servers
|
|
fi
|