mirror of
https://github.com/spantaleev/matrix-docker-ansible-deploy.git
synced 2025-01-14 20:27:18 +01:00
c0308307e2
This is an attempt at optimizing service startup. The effect is most pronounced when many services are restarted one by one. The systemd service manager role sometimes does this - for example when `just install-service synapse` runs. In such cases, a 5-second delay for each Synapse worker service (or other bridge/bot service that waits on the homeserver) quickly adds up to a lot. When services are all stopped fully and then started, the effect is not so pronounced, because `matrix-synapse.service` starts first and pulls all worker services (defined as `Wants=` for it). Later on, when the systemd service manager role "starts" these worker services, they're started already. Even if they had a 5-second wait each, it would have happened in parallel.
52 lines
2.5 KiB
Django/Jinja
52 lines
2.5 KiB
Django/Jinja
#jinja2: lstrip_blocks: "True"
|
||
[Unit]
|
||
Description=Conduit Matrix homeserver
|
||
{% for service in matrix_conduit_systemd_required_services_list %}
|
||
Requires={{ service }}
|
||
After={{ service }}
|
||
{% endfor %}
|
||
|
||
[Service]
|
||
Type=simple
|
||
Environment="HOME={{ devture_systemd_docker_base_systemd_unit_home_path }}"
|
||
ExecStartPre=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} stop --time={{ devture_systemd_docker_base_container_stop_grace_time_seconds }} matrix-conduit 2>/dev/null || true'
|
||
ExecStartPre=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} rm matrix-conduit 2>/dev/null || true'
|
||
|
||
ExecStartPre={{ devture_systemd_docker_base_host_command_docker }} create \
|
||
--rm \
|
||
--name=matrix-conduit \
|
||
--log-driver=none \
|
||
--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \
|
||
--cap-drop=ALL \
|
||
--read-only \
|
||
--tmpfs=/tmp:rw,noexec,nosuid,size={{ matrix_conduit_tmp_directory_size_mb }}m \
|
||
--network={{ matrix_conduit_container_network }} \
|
||
--env CONDUIT_CONFIG=/etc/matrix-conduit/conduit.toml \
|
||
--label-file={{ matrix_conduit_base_path }}/labels \
|
||
--mount type=bind,src={{ matrix_conduit_data_path }},dst=/var/lib/matrix-conduit \
|
||
--mount type=bind,src={{ matrix_conduit_config_path }},dst=/etc/matrix-conduit,ro \
|
||
{% for arg in matrix_conduit_container_extra_arguments %}
|
||
{{ arg }} \
|
||
{% endfor %}
|
||
{{ matrix_conduit_docker_image }}
|
||
|
||
{% for network in matrix_conduit_container_additional_networks %}
|
||
ExecStartPre={{ devture_systemd_docker_base_host_command_docker }} network connect {{ network }} matrix-conduit
|
||
{% endfor %}
|
||
|
||
ExecStart={{ devture_systemd_docker_base_host_command_docker }} start --attach matrix-conduit
|
||
|
||
# Intentional delay, so that the homeserver can manage to start and various services
|
||
# that depend on it (After/Requires) may only start after the homeserver is up and running.
|
||
ExecStartPost=-{{ matrix_host_command_sleep }} 3
|
||
|
||
ExecStop=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} stop --time={{ devture_systemd_docker_base_container_stop_grace_time_seconds }} matrix-conduit 2>/dev/null || true'
|
||
ExecStop=-{{ devture_systemd_docker_base_host_command_sh }} -c '{{ devture_systemd_docker_base_host_command_docker }} rm matrix-conduit 2>/dev/null || true'
|
||
ExecReload={{ devture_systemd_docker_base_host_command_docker }} exec matrix-conduit /bin/sh -c 'kill -HUP 1'
|
||
Restart=always
|
||
RestartSec=30
|
||
SyslogIdentifier=matrix-conduit
|
||
|
||
[Install]
|
||
WantedBy=multi-user.target
|