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
25 lines
1 KiB
YAML
25 lines
1 KiB
YAML
---
|
|
- name: remove-node | List nodes
|
|
command: >-
|
|
{{ bin_dir }}/kubectl get nodes -o go-template={% raw %}'{{ range .items }}{{ .metadata.name }}{{ "\n" }}{{ end }}'{% endraw %}
|
|
register: nodes
|
|
delegate_to: "{{ groups['kube_control_plane']|first }}"
|
|
changed_when: false
|
|
run_once: true
|
|
|
|
- name: remove-node | Drain node except daemonsets resource # noqa 301
|
|
command: >-
|
|
{{ bin_dir }}/kubectl --kubeconfig {{ kube_config_dir }}/admin.conf drain
|
|
--force
|
|
--ignore-daemonsets
|
|
--grace-period {{ drain_grace_period }}
|
|
--timeout {{ drain_timeout }}
|
|
--delete-emptydir-data {{ kube_override_hostname|default(inventory_hostname) }}
|
|
# ignore servers that are not nodes
|
|
when: kube_override_hostname|default(inventory_hostname) in nodes.stdout_lines
|
|
register: result
|
|
failed_when: result.rc != 0 and not allow_ungraceful_removal
|
|
delegate_to: "{{ groups['kube_control_plane']|first }}"
|
|
until: result.rc == 0 or allow_ungraceful_removal
|
|
retries: "{{ drain_retries }}"
|
|
delay: "{{ drain_retry_delay_seconds }}"
|