Files
linone-infra/roles/docker/tasks/main.yaml

144 lines
3.0 KiB
YAML

---
- name: Ensure docker root dir
file:
path: "{{docker.project_path}}"
state: directory
owner: root
group: root
- name: Ensure gitea root dir
file:
path: "{{docker.gitea.volumes_path}}"
state: directory
owner: gitea
group: root
- name: Ensure gitea conf dir
file:
path: "{{docker.gitea.volumes_path}}/gitea/conf"
state: directory
owner: gitea
group: root
- name: Ensure gitea conf file
template:
src: gitea.ini
dest: "{{docker.gitea.volumes_path}}/gitea/conf/app.ini"
owner: gitea
group: ansible
register: gitea_conf_file
- name: Ensure traefik root dir
file:
path: "{{docker.traefik.volumes_path}}"
state: directory
owner: traefik
group: root
- name: Ensure monitor root dir
file:
path: "{{docker.monitor.volumes_path}}"
state: directory
owner: monitor
group: root
- name: Ensure monitor sites dir
file:
path: "{{docker.monitor.sites_path}}"
state: directory
owner: monitor
group: root
# Docker service setup
- name: Update apt repositories
apt:
update_cache: yes
- name: Install apt dependencies
apt:
name:
- ca-certificates
- curl
- gnupg
state: present
- name: Add docker apt key
apt_key:
url: https://download.docker.com/linux/ubuntu/gpg
state: present
- name: Add docker apt repository
apt_repository:
repo: "deb [arch=amd64 signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu {{ubuntu_version_codename}} stable"
state: present
- name: Update apt repositories
apt:
update_cache: yes
- name: Install docker
apt:
name:
- docker-ce
- docker-ce-cli
- containerd.io
- docker-buildx-plugin
- docker-compose-plugin
state: present
# - name: Install requirements
# apt:
# name:
# - docker.io
# - docker-compose
# - python3-pip
# state: present
# - name: install requirements
# ansible.builtin.pip:
# name: docker
- name: Enable docker
systemd:
name: docker
enabled: yes
- name: Ensure docker-compose file
template:
src: docker-compose.yml
dest: "{{docker.project_path}}"
owner: ansible
group: ansible
register: docker_compose_file
- name: Rebuild docker projects
shell: |
cd {{docker.project_path}}
docker compose down
docker compose rm -f
docker compose pull
docker compose up -d
when: docker_compose_file.changed or gitea_conf_file.changed
# - name: Tear down existing project
# community.docker.docker_compose:
# project_src: "{{ docker.project_path }}"
# state: absent
# remove_orphans: yes
# when: docker_compose_file.changed
# - name: Set up project
# register: docker_project
# community.docker.docker_compose:
# project_src: "{{docker.project_path}}"
# state: present
# remove_orphans: yes
# when: docker_compose_file.changed
- name: debug
ansible.builtin.debug:
var: docker_project
when: docker_compose_file.changed