92f25bf267
- Use builtin task scheduling of ansible (same task on each host) instead of manual looping on master Benefits: - One less play in remove-node.yml playbook - Parralel node drain - Drain parameters (timeout, grace period, retries, allow_ungraceful_removal) can be adjusted separately for each node with ansible variables
42 lines
1.4 KiB
YAML
42 lines
1.4 KiB
YAML
---
|
|
- name: Check ansible version
|
|
import_playbook: ansible_version.yml
|
|
|
|
- name: Ensure compatibility with old groups
|
|
import_playbook: legacy_groups.yml
|
|
|
|
- hosts: "{{ node | default('etcd:k8s_cluster:calico_rr') }}"
|
|
gather_facts: no
|
|
tasks:
|
|
- name: Confirm Execution
|
|
pause:
|
|
prompt: "Are you sure you want to delete nodes state? Type 'yes' to delete nodes."
|
|
register: pause_result
|
|
run_once: True
|
|
when:
|
|
- not (skip_confirmation | default(false) | bool)
|
|
|
|
- name: Fail if user does not confirm deletion
|
|
fail:
|
|
msg: "Delete nodes confirmation failed"
|
|
when: pause_result.user_input | default('yes') != 'yes'
|
|
|
|
- name: Gather facts
|
|
import_playbook: facts.yml
|
|
|
|
- hosts: "{{ node | default('kube_node') }}"
|
|
gather_facts: no
|
|
environment: "{{ proxy_disable_env }}"
|
|
roles:
|
|
- { role: kubespray-defaults, when: reset_nodes|default(True)|bool }
|
|
- { role: remove-node/pre-remove, tags: pre-remove }
|
|
- { role: remove-node/remove-etcd-node }
|
|
- { role: reset, tags: reset, when: reset_nodes|default(True)|bool }
|
|
|
|
# Currently cannot remove first master or etcd
|
|
- hosts: "{{ node | default('kube_control_plane[1:]:etcd[1:]') }}"
|
|
gather_facts: no
|
|
environment: "{{ proxy_disable_env }}"
|
|
roles:
|
|
- { role: kubespray-defaults, when: reset_nodes|default(True)|bool }
|
|
- { role: remove-node/post-remove, tags: post-remove }
|