mirror of
https://github.com/spantaleev/matrix-docker-ansible-deploy.git
synced 2024-11-10 12:47:39 +01:00
adcc6d9723
The migration is automatic. Existing users should experience a bit of
downtime until the playbook runs to completion, but don't need to do
anything manually.
This change is provoked by https://github.com/spantaleev/matrix-docker-ansible-deploy/pull/2535
While my statements there ("Traefik is a shared component among
sibling/related playbooks and should retain its global
non-matrix-prefixed name and path") do make sense, there's another point
of view as well.
With the addition of docker-socket-proxy support in bf2b540807
,
we potentially introduced another non-`matrix-`-prefixed systemd service
and global path (`/devture-container-socket-proxy`). It would have
started to become messy.
Traefik always being called `devture-traefik.service` and using the `/devture-traefik` path
has the following downsides:
- different playbooks may write to the same place, unintentionally,
before you disable the Traefik role in some of them.
If each playbook manages its own installation, no such conflicts
arise and you'll learn about the conflict when one of them starts its
Traefik service and fails because the ports are already in use
- the data is scattered - backing up `/matrix` is no longer enough when
some stuff lives in `/devture-traefik` or `/devture-container-socket-proxy` as well;
similarly, deleting `/matrix` is no longer enough to clean up
For this reason, the Traefik instance managed by this playbook
will now be called `matrix-traefik` and live under `/matrix/traefik`.
This also makes it obvious to users running multiple playbooks, which
Traefik instance (powered by which playbook) is the active one.
Previously, you'd look at `devture-traefik.service` and wonder which
role was managing it.
39 lines
1.2 KiB
Django/Jinja
39 lines
1.2 KiB
Django/Jinja
#jinja2: lstrip_blocks: "True"
|
|
#!/bin/bash
|
|
|
|
if [ "$(id -u)" != "0" ]; then
|
|
echo "This script must be executed as root! Aborting."
|
|
exit 1
|
|
fi
|
|
|
|
echo "WARNING! You are about to remove everything the playbook installs for {{ matrix_server_fqn_matrix }}: matrix, docker images,..."
|
|
echo -n "If you're sure you want to do this, type: 'Yes, I really want to remove everything!'"
|
|
read sure
|
|
|
|
if [ "$sure" != "Yes, I really want to remove everything!" ]; then
|
|
echo "Good thing I asked, exiting"
|
|
exit 0
|
|
else
|
|
echo "Stop and remove matrix services"
|
|
|
|
for s in $(find {{ devture_systemd_docker_base_systemd_path }}/ -type f -name "matrix-*" -printf "%f\n"); do
|
|
systemctl disable --now $s
|
|
rm -f {{ devture_systemd_docker_base_systemd_path }}/$s
|
|
done
|
|
|
|
systemctl daemon-reload
|
|
|
|
echo "Remove unused Docker images and resources"
|
|
docker system prune -af
|
|
|
|
echo "Remove Docker matrix network (should be gone already, but ..)"
|
|
docker network rm {{ matrix_docker_network }}
|
|
|
|
echo "This playbook creates a lot of matrix-* networks. Consider removing them manually ('docker network ls', followed by 'docker network rm NETWORK_NAME')"
|
|
|
|
echo "Remove {{ matrix_base_data_path }} directory"
|
|
rm -fr "{{ matrix_base_data_path }}"
|
|
exit 0
|
|
fi
|
|
|