Compare commits

..

13 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
HawkveltGiteaAdmin 24d69d8d66 containerRestart1 2021-06-17 01:53:42 +09:30
HawkveltGiteaAdmin eb0372ded4 remove merge text 2021-06-17 01:07:43 +09:30
HawkveltGiteaAdmin 8654f76936 Restart the container if fileChanged is defined 2021-06-17 01:04:27 +09:30
HawkveltGiteaAdmin db4c4fbefd Restart the container if fileChanged is defined 2021-06-17 01:03:25 +09:30
HawkveltGiteaAdmin 4f62020d89 Added a todo 2021-06-14 00:58:58 +09:30
HawkveltGiteaAdmin c06f636bfa Ditched CephFS 2021-06-09 21:53:46 +09:30
HawkveltGiteaAdmin 3b47f34642 s 2021-03-12 17:04:15 +10:30
2 changed files with 80 additions and 112 deletions
+62 -13
View File
@@ -56,6 +56,7 @@
#----------------------------------TEMPLATES----------------------------------
#Only copy template files if there are templates defined in the incoming defintion dict
- set_fact: templates_Defined=0
@@ -80,7 +81,8 @@
loop_var: outer_item
when: templates_Defined ==1 and outer_item.value.generic is not defined
tags: always
register: regular_template
notify: Restart container
#Copy templates form a generic dir, allow ansible to search
- 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
@@ -91,7 +93,8 @@
loop_var: outer_item
when: templates_Defined ==1 and outer_item.value.generic is defined
tags: always
register: generic_template
notify: Restart container
- name: Append templated files to the mapping list
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
@@ -132,6 +135,8 @@
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
tags: always
register: file_copy
notify: Restart container
#Copy files from a generic dir, allow ansible to search
- 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
@@ -142,6 +147,8 @@
loop_var: outer_item
when: files_Defined == 1 and outer_item.value.generic is defined and outer_item.value.src_text is not defined
tags: always
register: generic_copy
notify: Restart container
#Create files based on the suplied src_text param
- 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
@@ -152,6 +159,8 @@
loop_var: outer_item
when: files_Defined == 1 and outer_item.value.src_text is defined
tags: always
register: text_copy
notify: Restart container
- name: Append static remote files to the mapping list
set_fact:
@@ -208,12 +217,9 @@
tags: always
#----------------------------------/Check ENV----------------------------------
- name: "Container {{ container_Name }}"
become: yes
docker_container:
- name: Setup default values for this container
set_fact:
default:
name: "{{ container_Name }}"
hostname: "{{ item.value.hostname | default(container_Name) }}"
command: "{{ item.value.command | default('') }}"
@@ -231,9 +237,52 @@
network_mode: "{{ item.value.network_mode | default ('default') }}"
shm_size: "{{ item.value.shm_size | default ('64M') }}"
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
- 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
+4 -85
View File
@@ -1,93 +1,12 @@
# - name: "Checking docker volume {{working_volume_name}}"
# debug: msg="Checking docker volume {{working_volume_name}}"
#----------------------------------CephFS Volume----------------------------------
- set_fact: base_volume_name="cephFS_"
tags: always
- name: Set working_volume_name(staticName not defined)
set_fact: working_volume_name="{{base_volume_name+container_Name + '_' + item.value.volumeName}}"
when: item.value.staticName is not defined
tags: always
- name: Set working_volume_name(staticName IS defined)
set_fact: working_volume_name={{item.value.staticName}}
when: item.value.staticName is defined
tags: always
- name: "Create {{ containerConfigDir }}/docker/cephFS"
file:
path: "{{containerConfigDir}}/docker/cephFS"
state: directory
recurse: no
when: item.value.type=="cephfs"
tags: always
- name: "Create {{ containerConfigDir }}/docker/configs"
file:
path: "{{containerConfigDir}}/docker/configs"
state: directory
recurse: no
when: item.value.type=="cephfs"
tags: always
- name: Add CephFS mount to fstab
lineinfile:
dest=/etc/fstab
backup=yes
state=present
line='none {{containerConfigDir}}/docker/cephFS fuse.ceph ceph.id=admin,_netdev,defaults 0 0'
register: fstab
tags: mount,always
when: item.value.type=="cephfs"
- name: Mount FSTab
shell: "mount -a"
args:
warn: false
when: fstab.changed
tags: mount,always
- name: "Checking docker volume "
debug: msg="CephFS user {{ cephFS_user }} secret {{ cephFS_secret }}"
when: item.value.type=="cephfs"
tags: always
- name: "Create docker volume - {{ working_volume_name }}"
docker_volume:
name: "{{ working_volume_name }}"
driver: n0r1skcom/docker-volume-cephfs
driver_options:
name="{{cephFS_user}}"
path="/container/{{working_volume_name}}"
secret="{{cephFS_secret}}"
monitors="{{ceph_Mons}}"
register: dockerVolume
tags: volume,always
when: item.value.type=="cephfs"
# This is needed so that when Docker goes to mount the volume, the folder it's looking for actually exists
- name: Create {{containerConfigDir}}/docker/cephFS/container/{{working_volume_name}}
file:
path: "{{containerConfigDir}}/docker/cephFS/container/{{working_volume_name}}"
state: directory
recurse: no
when: dockerVolume.changed
tags: volume,always
when: item.value.type=="cephfs"
- name: Append the volume to the container mapping list(mappings var defined in dockerContainer.yml)
set_fact:
mappings: "{{ mappings + [ working_volume_name + ':' + item.value.dest + ':' + item.value.params | default('rw') ] }}"
when: item.value.type=="cephfs"
tags: always
#----------------------------------/CephFS Volume----------------------------------
# ----------------------------------Local Volume----------------------------------
- set_fact: base_volume_name="local_"
- name: Set working_volume_name(staticName not defined)
tags: always
- name: xSet working_volume_name(staticName not defined)
set_fact: working_volume_name="{{base_volume_name+container_Name + '_' + item.value.volumeName}}"
when: item.value.staticName is not defined
tags: always