Compare commits
6 Commits
0111f74f0f
...
transcaffe
Author | SHA1 | Date | |
---|---|---|---|
038ad4b07e
|
|||
e27eb145f1
|
|||
c286e1a6b4
|
|||
517a2fe96c
|
|||
9d4baad491
|
|||
0090baee97
|
16
playbooks/docker_registry.yml
Normal file
16
playbooks/docker_registry.yml
Normal file
@ -0,0 +1,16 @@
|
||||
---
|
||||
- name: Manage docker registry credentials
|
||||
hosts: "{{ docker_hosts | default('docker', true) }}"
|
||||
become: "{{ docker_become | default(false) }}"
|
||||
gather_facts: "{{ docker_registry_gather_facts | default(true) }}"
|
||||
tasks:
|
||||
- name: Manage docker registry credentials
|
||||
community.docker.docker_login:
|
||||
registry_url: "{{ docker_registry.registry }}"
|
||||
username: "{{ docker_registry.username | default(omit) }}"
|
||||
password: "{{ docker_registry.password | default(omit) }}"
|
||||
state: "{{ docker_registry.state | default('present') }}"
|
||||
loop: "{{ docker_registries | default([], true) }}"
|
||||
loop_control:
|
||||
loop_var: "docker_registry"
|
||||
label: "{{ docker_registry.username}}@{{ docker_registry.registry }}"
|
10
playbooks/hostname.yml
Normal file
10
playbooks/hostname.yml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
- name: Ensure hostname is managed
|
||||
hosts: "{{ hostname_targets | default('hostname_managed') }}"
|
||||
become: "{{ hostname_target_become | default(true) }}"
|
||||
gather_facts: false
|
||||
tasks:
|
||||
- name: Ensure hostname is up to date
|
||||
ansible.builtin.hostname:
|
||||
name: "{{ hostname | default(inventory_hostname, true) }}"
|
||||
use: "{{ hostname_strategy | default(omit, true) }}"
|
34
roles/docker/defaults/main/fedora.yml
Normal file
34
roles/docker/defaults/main/fedora.yml
Normal file
@ -0,0 +1,34 @@
|
||||
---
|
||||
docker_fedora_repo_name: "docker-ce-stable"
|
||||
docker_fedora_repo_description: "Docker CE Stable - $basearch"
|
||||
docker_fedora_repo_url: "https://download.docker.com/linux/fedora/$releasever/$basearch/stable"
|
||||
docker_fedora_repo_validate_certs: true
|
||||
docker_fedora_repo_gpg_check: true
|
||||
docker_fedora_repo_gpg_key: "https://download.docker.com/linux/fedora/gpg"
|
||||
|
||||
docker_fedora_cli_package: "docker-ce-cli"
|
||||
docker_fedora_plugin_buildx_package: "docker-buildx-plugin"
|
||||
docker_fedora_plugin_compose_package: "docker-compose-plugin"
|
||||
docker_fedora_base_packages:
|
||||
- "docker-ce"
|
||||
- "docker-ce-cli"
|
||||
- "containerd.io"
|
||||
docker_fedora_packages: >-2
|
||||
{{
|
||||
docker_fedora_base_packages
|
||||
+ (docker_plugin_buildx_enable | default(false)
|
||||
| ternary([ docker_fedora_plugin_buildx_package ], []))
|
||||
+ (docker_plugin_compose_enable | default(false)
|
||||
| ternary([ docker_fedora_plugin_compose_package ], []))
|
||||
}}
|
||||
docker_fedora_legacy_packages:
|
||||
- "docker"
|
||||
- "docker-client"
|
||||
- "docker-client-latest"
|
||||
- "docker-common"
|
||||
- "docker-latest"
|
||||
- "docker-latest-logrotate"
|
||||
- "docker-logrotate"
|
||||
- "docker-selinux"
|
||||
- "docker-engine-selinux"
|
||||
- "docker-engine"
|
@ -9,7 +9,7 @@
|
||||
|
||||
- name: Configure docker daemon using '{{ docker_daemon_config_file }}'
|
||||
ansible.builtin.copy:
|
||||
content: "{{ docker_daemon_config | to_json }}"
|
||||
content: "{{ docker_daemon_config | to_nice_json }}"
|
||||
dest: "{{ docker_daemon_config_file }}"
|
||||
mode: "{{ docker_daemon_config_file_mode }}"
|
||||
owner: "{{ docker_daemon_config_owner }}"
|
||||
|
21
roles/docker/tasks/install-fedora.yml
Normal file
21
roles/docker/tasks/install-fedora.yml
Normal file
@ -0,0 +1,21 @@
|
||||
---
|
||||
- name: Ensure legacy docker packages are removed
|
||||
ansible.builtin.dnf:
|
||||
name: "{{ docker_fedora_legacy_packages }}"
|
||||
state: "removed"
|
||||
when: docker_remove_legacy_packages
|
||||
|
||||
- name: Ensure dnf repository for docker is {{ docker_state }}
|
||||
ansible.builtin.yum_repository:
|
||||
name: "{{ docker_fedora_repo_name }}"
|
||||
description: "{{ docker_fedora_repo_description }}"
|
||||
baseurl: "{{ docker_fedora_repo_url }}"
|
||||
validate_certs: "{{ docker_fedora_repo_validate_certs }}"
|
||||
gpgkey: "{{ docker_fedora_repo_gpg_key }}"
|
||||
gpgcheck: "{{ docker_fedora_repo_gpg_check }}"
|
||||
state: "{{ docker_state }}"
|
||||
|
||||
- name: Install dnf packages for docker
|
||||
ansible.builtin.dnf:
|
||||
name: "{{ docker_fedora_packages }}"
|
||||
state: "{{ docker_state }}"
|
@ -2,14 +2,14 @@
|
||||
- name: Check if target OS is supported
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
OS Family '{{ docker_os_family }}' is not supported!
|
||||
when: docker_os_family not in docker_supported_os_families
|
||||
OS '{{ docker_os }}' is not supported!
|
||||
when: docker_os not in docker_supported_oses
|
||||
vars:
|
||||
docker_os_family: "{{ ansible_os_family | lower }}"
|
||||
docker_os: "{{ ansible_distribution | lower }}"
|
||||
|
||||
- name: Ensure docker is {{ docker_state }} on {{ ansible_os_family }}-family
|
||||
- name: Ensure docker is {{ docker_state }} on {{ ansible_distribution }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "install-{{ ansible_os_family | lower }}.yml"
|
||||
file: "install-{{ ansible_distribution | lower }}.yml"
|
||||
|
||||
- name: Configure docker daemon
|
||||
ansible.builtin.include_tasks:
|
||||
|
@ -1,3 +1,4 @@
|
||||
---
|
||||
docker_supported_os_families:
|
||||
docker_supported_oses:
|
||||
- 'debian'
|
||||
- 'fedora'
|
||||
|
@ -107,6 +107,7 @@
|
||||
{{ entry.key }}={{ entry.value }}
|
||||
{% endfor %}
|
||||
dest: "{{ lego_base_path }}/{{ lego_instance }}.conf"
|
||||
register: lego_env_file_info
|
||||
|
||||
- name: Ensure timer unit is templated
|
||||
ansible.builtin.template:
|
||||
@ -120,6 +121,7 @@
|
||||
src: "lego_run.sh"
|
||||
dest: "{{ lego_base_path }}/run.sh"
|
||||
mode: "0755"
|
||||
register: lego_handler_script_info
|
||||
|
||||
- name: Ensure per-instance base path is created
|
||||
ansible.builtin.file:
|
||||
@ -159,7 +161,18 @@
|
||||
name: "{{ lego_systemd_timer_name }}"
|
||||
state: "started"
|
||||
|
||||
- name: Check if certificates are present
|
||||
ansible.builtin.find:
|
||||
path: "{{ lego_instance_path }}/certificates"
|
||||
recurse: false
|
||||
file_type: "file"
|
||||
register: lego_certificate_info
|
||||
|
||||
- name: Ensure systemd service is started once to obtain the certificate
|
||||
ansible.builtin.systemd_service:
|
||||
name: "{{ lego_systemd_service_name }}"
|
||||
state: "started"
|
||||
when: >-2
|
||||
lego_handler_script_info.changed
|
||||
or lego_env_file_info.changed
|
||||
or lego_certificate_info.files | default([]) | length == 0
|
||||
|
@ -1,7 +1,7 @@
|
||||
---
|
||||
minio_container_name: minio
|
||||
minio_container_image_name: "docker.io/minio/minio"
|
||||
minio_container_image_tag: "RELEASE.2025-04-08T15-41-24Z"
|
||||
minio_container_image_tag: "RELEASE.2025-04-22T22-12-26Z"
|
||||
minio_container_image: "{{ minio_container_image_name }}:{{ minio_container_image_tag }}"
|
||||
minio_container_networks: []
|
||||
minio_container_ports: []
|
||||
|
@ -1,5 +1,5 @@
|
||||
---
|
||||
nginx_version: "1.27.5"
|
||||
nginx_version: "1.28.0"
|
||||
nginx_flavour: alpine
|
||||
nginx_base_path: /opt/nginx
|
||||
nginx_config_file: "{{ nginx_base_path }}/nginx.conf"
|
||||
|
Reference in New Issue
Block a user