Skip to content

linux-system-roles/systemd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

systemd

ansible-lint.yml ansible-test.yml codeql.yml markdownlint.yml python-unit-test.yml shellcheck.yml tft.yml tft_citest_bad.yml woke.yml

template

Ansible role that can be used to deploy unit files and manage systemd units. Role is a convenience wrapper around systemd and template Ansible Core modules.

Requirements

See below

Collection requirements

In order to manage rpm-ostree systems, the role requires modules from external collections. Use the following command to install them:

ansible-galaxy collection install -vv -r meta/collection-requirements.yml

Role Variables

List of variables consumed by the role follows, note that none of them is mandatory.

systemd_unit_files

List of systemd unit file names that should be deployed to managed nodes.

systemd_unit_file_templates

List of systemd unit file names that should be deployed to managed nodes. Each name should correspond to Jinja template file that will be templated out to managed nodes. If the local file has a .j2 suffix it will be stripped to form the service name.

systemd_dropins

List of systemd drop in files that will be templated out to managed hosts and will extend respective systemd unit files. Name of the unit file that given entry extends is encoded in the name of the entry itself. For example, for entry foo.service.conf it is expected that foo.service.conf Jinja template exists and resulting dropin file will extend foo.service unit file. If the local file has a .j2 suffix it will be stripped to form the service name.

systemd_started_units

List of unit names that shall be started via systemd.

systemd_stopped_units

List of unit names that shall be stopped via systemd.

systemd_restarted_units

List of unit names that shall be restarted via systemd.

systemd_reloaded_units

List of unit names that shall be reloaded via systemd.

systemd_enabled_units

List of unit files that shall be enabled via systemd.

systemd_disabled_units

List of unit files that shall be disabled via systemd.

systemd_masked_units

List of unit files that shall be masked via systemd.

systemd_unmasked_units

List of unit files that shall be unmasked via systemd.

systemd_transactional_update_reboot_ok

This variable is used to handle reboots required by transactional updates. If a transactional update requires a reboot, the role will proceed with the reboot if systemd_transactional_update_reboot_ok is set to true. If set to false, the role will notify the user that a reboot is required, allowing for custom handling of the reboot requirement. If this variable is not set, the role will fail to ensure the reboot requirement is not overlooked.

Example of setting the variables:

systemd_unit_files:
  - foo.service
  - bar.service
systemd_dropins:
  - cups.service.conf.j2
  - avahi-daemon.service.conf.j2
systemd_started_units:
  - foo.service
  - bar.service
systemd_enabled_units:
  - foo.service
  - bar.service

Variables Exported by the Role

systemd_units

Variable shall contain a list of dictionaries where each entry describes state of one systemd unit present on the managed host.

Example Playbook

- name: Deploy and start systemd unit
  hosts: all
  vars:
    systemd_unit_file_templates:
      - foo.service.j2
    systemd_started_units:
      - foo.service
    systemd_enabled_units:
      - foo.service
  roles:
    - linux-system-roles.systemd

rpm-ostree

See README-ostree.md

License

MIT

Author

Michal Sekletar [email protected]