Adjusting teardown, add hosts ip updater

This commit is contained in:
László Károlyi 2017-03-14 22:43:13 +01:00
parent 34c5409d49
commit f8a50e8623
No known key found for this signature in database
GPG key ID: 372AA22D38BD5B13
2 changed files with 49 additions and 13 deletions

View file

@ -1,3 +1,8 @@
- name: Fail when jail_id not specified
fail:
msg: jail_id must be defined for teardown.yml, bailing out
when: '{{ jail_id|default(False) == False }}'
- name: Check if the jail {{ jail_id }} runs - name: Check if the jail {{ jail_id }} runs
set_fact: set_fact:
jail_is_old_running: >- jail_is_old_running: >-
@ -8,6 +13,14 @@
/usr/sbin/jail -r {{ jail_id }} /usr/sbin/jail -r {{ jail_id }}
when: jail_is_old_running when: jail_is_old_running
- name: Removing config block for {{ jail_id }} from /etc/jail.conf
blockinfile:
state: absent
dest: '/etc/jail.conf'
# Keep this line at the bottom so vim can use proper syntax higlighting
insertbefore: '^# vim: syn=conf$'
marker: '# {mark} ANSIBLE MANAGED BLOCK: {{ jail_id }}'
- name: Getting mounts under this jail - name: Getting mounts under this jail
shell: shell:
/sbin/mount -p /sbin/mount -p
@ -25,11 +38,26 @@
loop_control: loop_control:
loop_var: mountpoint loop_var: mountpoint
- name: Destroying ZFS mount - name: Delete config dir for jail
file:
path: '{{ dynamic_jails_path }}/configs/{{ jail_id }}'
state: absent
- name: Destroying ZFS dataset {{ dynamic_jails_dataset_name }}/{{ jail_id }}
zfs: zfs:
name: >- name: >-
{{ dynamic_jails_dataset_name }}/{{ jail_id }} {{ dynamic_jails_dataset_name }}/{{ jail_id }}
state: absent state: absent
register: zfs_destroy
ignore_errors: yes
# Due to a possible bug in the ZFS/FreeBSD kernel, destroying the dataset
# sometimes isn't possible after freeing it up. Hence we use '-f'
- name: Force-destroying ZFS dataset {{ dynamic_jails_dataset_name }}/{{ jail_id }} because it failed formerly
command:
/sbin/zfs destroy -f
{{ dynamic_jails_dataset_name }}/{{ jail_id }}
when: zfs_destroy | failed
- name: Removing jail directory - name: Removing jail directory
file: file:
@ -37,15 +65,3 @@
{{ dynamic_jails_path }}/{{ jail_id }} {{ dynamic_jails_path }}/{{ jail_id }}
state: absent state: absent
- name: Removing config block for {{ jail_id }} from /etc/jail.conf
blockinfile:
state: absent
dest: '/etc/jail.conf'
# Keep this line at the bottom so vim can use proper syntax higlighting
insertbefore: '^# vim: syn=conf$'
marker: '# {mark} ANSIBLE MANAGED BLOCK: {{ jail_id }}'
- name: Delete config dir for jail
file:
path: '{{ dynamic_jails_path }}/configs/{{ jail_id }}'
state: absent

View file

@ -0,0 +1,20 @@
# IMPORTANT: after the IP that is 2 TABULATOR character
- name: Getting matching /etc/hosts files
command: >-
/bin/sh -c "/usr/bin/grep -lE
'^[0-9]+.[0-9]+.[0-9]+.[0-9]+ jail_{{ jail_name }}'
/usr/jails/*/etc/hosts {{ dynamic_jails_path }}/*/etc/hosts"
ignore_errors: yes
failed_when: false
register: matching_hosts_files
- name: Replacing appropriate jail names with new IP addresses in /etc/hosts files
lineinfile:
dest: '{{ filename }}'
regexp: '^\d+\.\d+\.\d+\.\d+ jail_{{ jail_name }}'
line: '{{ vars["jail_" + jail_name + "_new_ip"] }} jail_{{ jail_name }}'
state: present
with_items: '{{ matching_hosts_files.stdout_lines }}'
loop_control:
loop_var: filename