diff --git a/roles/postgresql/defaults/main.yml b/roles/postgresql/defaults/main.yml index fd28914..6655d89 100644 --- a/roles/postgresql/defaults/main.yml +++ b/roles/postgresql/defaults/main.yml @@ -6,7 +6,7 @@ postgresql_socket_path: "{{ postgresql_base_path }}/sockets" postgresql_config_path: "{{ postgresql_base_path }}/config" postgresql_connect_socket: true -postgresql_container_version: "13.11" +postgresql_container_version: "13" postgresql_container_distro: "alpine" postgresql_container_image_reference: >- diff --git a/roles/postgresql/tasks/main.yml b/roles/postgresql/tasks/main.yml index fb67eef..d47c11d 100644 --- a/roles/postgresql/tasks/main.yml +++ b/roles/postgresql/tasks/main.yml @@ -7,14 +7,6 @@ register: "postgresql_user_res" tags: ["prepare", "prepare-postgresql", "deploy", "deploy-postgresql"] -- name: "Ensure PostgreSQL container image is pulled" - community.docker.docker_image: - name: "{{ postgresql_container_image_reference }}" - force_source: "{{ postgresql_container_pull }}" - source: "pull" - state: "present" - tags: ["prepare", "prepare-postgresql"] - - name: "Check if postgresql_data_path exists" stat: path: "{{ postgresql_data_path }}" @@ -29,6 +21,57 @@ register: "find_postgresql_data_path" tags: ["prepare", "prepare-postgresql"] +- name: "Check if container {{ postgresql_container_name }} already exists on host" + community.docker.docker_container_info: + name: "{{ postgresql_container_name }}" + register: "postgresql_active_container" + tags: ["prepare", "prepare-postgresql"] + +- name: "Set postgresql_active_container_major_version" + ansible.builtin.set_fact: + postgresql_active_container_major_version: >-2 + {{ + postgresql_active_container.container.Config.Env + | select('search', '^PG_MAJOR=') + | first + | split('=') + | last + }} + when: "postgresql_active_container.exists" + tags: ["prepare", "prepare-postgresql"] + +- name: "Prevent major version update, use major version of existing container instead" + ansible.builtin.set_fact: + postgresql_container_version: "{{ postgresql_active_container_major_version }}" + when: + - "postgresql_active_container.exists" + - "(postgresql_container_version | int) != (postgresql_active_container_major_version | int)" + tags: ["prepare", "prepare-postgresql"] + +- name: "Ensure image {{ postgresql_container_image_reference }} is pulled" + community.docker.docker_image: + name: "{{ postgresql_container_image_reference }}" + force_source: "{{ postgresql_container_pull }}" + source: "pull" + state: "present" + register: "postgresql_image_pulled" + tags: ["prepare", "prepare-postgresql"] + +- name: "Set container version label to exact version of pulled image" + ansible.builtin.set_fact: + postgresql_container_labels_base: + version: >-2 + {{ + postgresql_image_pulled.image.Config.Env + | select('search', '^PG_VERSION=') + | first + | split('=') + | last + | string + }} + when: "postgresql_image_pulled.image.Config is defined" + tags: ["prepare", "prepare-postgresql"] + - name: "Initialize" include_tasks: "initialize.yml" when: >-