Compare commits

...

6 Commits

Author SHA1 Message Date
coryHawkvelt a99dbaee07 Includes conditional setting for ulimts and devices 2022-11-17 00:37:48 +10:30
coryHawkvelt f0a6a7d51a changed defaultto None 2022-10-22 01:18:28 +10:30
coryHawkvelt 3c2d85f480 Add devices 2022-10-22 01:03:01 +10:30
coryHawkvelt 56beaa8208 Rollback ulimits 2022-10-11 00:18:19 +10:30
HawkveltGiteaAdmin 7016ab2464 Upd 2022-10-10 14:40:59 +10:30
HawkveltGiteaAdmin 032cc44c2b Upd 2022-10-10 14:39:36 +10:30
2 changed files with 77 additions and 64 deletions
+63 -50
View File
@@ -56,6 +56,7 @@
#----------------------------------TEMPLATES---------------------------------- #----------------------------------TEMPLATES----------------------------------
#Only copy template files if there are templates defined in the incoming defintion dict #Only copy template files if there are templates defined in the incoming defintion dict
- set_fact: templates_Defined=0 - set_fact: templates_Defined=0
@@ -79,13 +80,9 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: templates_Defined ==1 and outer_item.value.generic is not defined when: templates_Defined ==1 and outer_item.value.generic is not defined
register: fileChanged
tags: always tags: always
- name: Set the flag to restart the container if file was changed register: regular_template
set_fact: containerRestart='yes' notify: Restart container
when: fileChanged is defined and fileChanged.changed
tags: always
#Copy templates form a generic dir, allow ansible to search #Copy templates form a generic dir, allow ansible to search
- name: "Generic template mappings for {{ container_Name }}" - name: "Generic template mappings for {{ container_Name }}"
#Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their template file name but with the '.j2' stripped #Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their template file name but with the '.j2' stripped
@@ -95,13 +92,9 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: templates_Defined ==1 and outer_item.value.generic is defined when: templates_Defined ==1 and outer_item.value.generic is defined
register: fileChanged
tags: always tags: always
- name: Set the flag to restart the container if file was changed register: generic_template
set_fact: containerRestart='yes' notify: Restart container
when: fileChanged is defined and fileChanged.changed
tags: always
- name: Append templated files to the mapping list - name: Append templated files to the mapping list
set_fact: set_fact:
#build a list to pass to docker containing the source of the file(As on disk on the host) and the destination mount within the container #build a list to pass to docker containing the source of the file(As on disk on the host) and the destination mount within the container
@@ -141,12 +134,9 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: files_Defined == 1 and outer_item.value.generic is not defined and outer_item.value.src_text is not defined when: files_Defined == 1 and outer_item.value.generic is not defined and outer_item.value.src_text is not defined
register: fileChanged
tags: always
- name: Set the flag to restart the container if file was changed
set_fact: containerRestart='yes'
when: fileChanged is defined and fileChanged.changed
tags: always tags: always
register: file_copy
notify: Restart container
#Copy files from a generic dir, allow ansible to search #Copy files from a generic dir, allow ansible to search
- name: "Generic File mappings for {{ container_Name }}" - name: "Generic File mappings for {{ container_Name }}"
#Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their file name #Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their file name
@@ -156,13 +146,9 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: files_Defined == 1 and outer_item.value.generic is defined and outer_item.value.src_text is not defined when: files_Defined == 1 and outer_item.value.generic is defined and outer_item.value.src_text is not defined
register: fileChanged
tags: always tags: always
- name: Set the flag to restart the container if file was changed register: generic_copy
set_fact: containerRestart='yes' notify: Restart container
when: fileChanged is defined and fileChanged.changed
tags: always
#Create files based on the suplied src_text param #Create files based on the suplied src_text param
- name: "Text based file creation for {{ container_Name }}" - name: "Text based file creation for {{ container_Name }}"
#Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their file name #Files will be copied to the 'config' dir as defined by container_configDir, they will be stored using their file name
@@ -172,12 +158,9 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: files_Defined == 1 and outer_item.value.src_text is defined when: files_Defined == 1 and outer_item.value.src_text is defined
register: fileChanged
tags: always
- name: Set the flag to restart the container if file was changed
set_fact: containerRestart='yes'
when: fileChanged is defined and fileChanged.changed
tags: always tags: always
register: text_copy
notify: Restart container
- name: Append static remote files to the mapping list - name: Append static remote files to the mapping list
set_fact: set_fact:
@@ -218,14 +201,7 @@
loop_control: loop_control:
loop_var: outer_item loop_var: outer_item
when: local_Defined == 1 when: local_Defined == 1
register: fileChanged
tags: always tags: always
- name: Set the flag to restart the container if file was changed
set_fact: containerRestart='yes'
when: fileChanged is defined and fileChanged.changed
tags: always
#----------------------------------/LOCAL---------------------------------- #----------------------------------/LOCAL----------------------------------
@@ -241,15 +217,9 @@
tags: always tags: always
#----------------------------------/Check ENV---------------------------------- #----------------------------------/Check ENV----------------------------------
- name: Restart the container if fileChanged is defined - name: Setup default values for this container
set_fact: containerRestart1='yes' set_fact:
when: (containerRestart is defined and containerRestart=='yes') or (item.value.restart is defined and item.value.restart =='yes') default:
- name: "Container {{ container_Name }}"
become: yes
docker_container:
name: "{{ container_Name }}" name: "{{ container_Name }}"
hostname: "{{ item.value.hostname | default(container_Name) }}" hostname: "{{ item.value.hostname | default(container_Name) }}"
command: "{{ item.value.command | default('') }}" command: "{{ item.value.command | default('') }}"
@@ -257,7 +227,7 @@
recreate: "{{ item.value.recreate | default('false') }}" recreate: "{{ item.value.recreate | default('false') }}"
image: "{{ item.value.image }}" image: "{{ item.value.image }}"
state: "{{ item.value.start | default ('started') }}" state: "{{ item.value.start | default ('started') }}"
restart: "{{ containerRestart1 | default ('no') }}" restart: "{{ item.value.restart | default ('no') }}"
restart_policy: "{{ item.value.restart_policy | default ('always') }}" restart_policy: "{{ item.value.restart_policy | default ('always') }}"
purge_networks: "{{ item.value.purge_networks | default ('yes') }}" purge_networks: "{{ item.value.purge_networks | default ('yes') }}"
networks: "{{ net_checked }}" networks: "{{ net_checked }}"
@@ -267,9 +237,52 @@
network_mode: "{{ item.value.network_mode | default ('default') }}" network_mode: "{{ item.value.network_mode | default ('default') }}"
shm_size: "{{ item.value.shm_size | default ('64M') }}" shm_size: "{{ item.value.shm_size | default ('64M') }}"
ports: "{{ item.value.ports | default ([]) }}" ports: "{{ item.value.ports | default ([]) }}"
#log_driver: fluentd
#"{{item.value.ports | default ([json-file])}}"
#log_options:
# fluentd-sub-second-precision: true
# tag: myservice
tags: always tags: always
- name: Setup devices_override blank
set_fact:
devices_override:
tags: always
- name: Setup ulimit_override blank
set_fact:
ulimit_override:
tags: always
#----------Merge ulimits--------------
- name: Apply conditional override
set_fact:
ulimit_override:
ulimits: "{{ item.value.ulimits }}"
when: item.value.ulimits is defined
tags: always
- name: Merge the two lists
set_fact:
ulimits_merged: "{{ default | combine(ulimit_override, recursive=true) }}"
tags: always
#----------Merge devices--------------
- name: Apply conditional override
set_fact:
devices_override:
devices: "{{ item.value.devices }}"
when: item.value.devices is defined
tags: always
- name: Merge the two lists
set_fact:
final_merged: "{{ ulimits_merged | combine(devices_override, recursive=true) }}"
tags: always
- name: debug value
debug:
msg: "{{final_merged}}"
tags: always
- name: "Container {{ container_Name }}"
become: true
docker_container: "{{ final_merged }}"
tags: always
+2 -2
View File
@@ -1,7 +1,7 @@
#- name: "Checking docker volume {{working_volume_name}}" # - name: "Checking docker volume {{working_volume_name}}"
# debug: msg="Checking docker volume {{working_volume_name}}" # debug: msg="Checking docker volume {{working_volume_name}}"
#----------------------------------Local Volume---------------------------------- # ----------------------------------Local Volume----------------------------------
- set_fact: base_volume_name="local_" - set_fact: base_volume_name="local_"
tags: always tags: always