remove ectd node in pre step, instead of post step (#6099)
This commit is contained in:
parent
101686c665
commit
7712bd0c76
3 changed files with 43 additions and 38 deletions
|
@ -29,6 +29,7 @@
|
||||||
gather_facts: no
|
gather_facts: no
|
||||||
roles:
|
roles:
|
||||||
- { role: kubespray-defaults }
|
- { role: kubespray-defaults }
|
||||||
|
- { role: remove-node/remove-etcd-node}
|
||||||
- { role: reset, tags: reset, when: reset_nodes|default(True) }
|
- { role: reset, tags: reset, when: reset_nodes|default(True) }
|
||||||
|
|
||||||
# Currently cannot remove first master or etcd
|
# Currently cannot remove first master or etcd
|
||||||
|
|
|
@ -11,45 +11,7 @@
|
||||||
delegate_to: "{{ groups['etcd']|first }}"
|
delegate_to: "{{ groups['etcd']|first }}"
|
||||||
failed_when: false
|
failed_when: false
|
||||||
|
|
||||||
- name: Set node IP
|
|
||||||
set_fact:
|
|
||||||
node_ip: "{{ ip | default(access_ip | default(remove_node_ip.stdout)) | trim }}"
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups['etcd']
|
|
||||||
|
|
||||||
- name: Delete node
|
- name: Delete node
|
||||||
command: "{{ bin_dir }}/kubectl delete node {{ inventory_hostname }}"
|
command: "{{ bin_dir }}/kubectl delete node {{ inventory_hostname }}"
|
||||||
delegate_to: "{{ groups['kube-master']|first }}"
|
delegate_to: "{{ groups['kube-master']|first }}"
|
||||||
ignore_errors: yes
|
ignore_errors: yes
|
||||||
|
|
||||||
- name: Lookup etcd member id
|
|
||||||
shell: "{{ bin_dir }}/etcdctl --no-sync --endpoints={{ etcd_access_addresses }} member list | grep {{ node_ip }} | cut -d: -f1"
|
|
||||||
register: etcd_member_id
|
|
||||||
ignore_errors: true
|
|
||||||
changed_when: false
|
|
||||||
check_mode: no
|
|
||||||
tags:
|
|
||||||
- facts
|
|
||||||
environment:
|
|
||||||
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}.pem"
|
|
||||||
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}-key.pem"
|
|
||||||
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|
|
||||||
delegate_to: "{{ groups['etcd']|first }}"
|
|
||||||
when: inventory_hostname in groups['etcd']
|
|
||||||
|
|
||||||
- name: Remove etcd member from cluster
|
|
||||||
shell: "{{ bin_dir }}/etcdctl --no-sync --endpoints={{ etcd_access_addresses }} member remove {{ etcd_member_id.stdout }}"
|
|
||||||
register: etcd_member_in_cluster
|
|
||||||
ignore_errors: true
|
|
||||||
changed_when: false
|
|
||||||
check_mode: no
|
|
||||||
tags:
|
|
||||||
- facts
|
|
||||||
environment:
|
|
||||||
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}.pem"
|
|
||||||
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}-key.pem"
|
|
||||||
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|
|
||||||
delegate_to: "{{ groups['etcd']|first }}"
|
|
||||||
when:
|
|
||||||
- inventory_hostname in groups['etcd']
|
|
||||||
- etcd_member_id.stdout | length > 0
|
|
||||||
|
|
42
roles/remove-node/remove-etcd-node/tasks/main.yml
Normal file
42
roles/remove-node/remove-etcd-node/tasks/main.yml
Normal file
|
@ -0,0 +1,42 @@
|
||||||
|
---
|
||||||
|
- name: Set node IP
|
||||||
|
set_fact:
|
||||||
|
node_ip: "{{ ip | default(access_ip | default(remove_node_ip.stdout)) | trim }}"
|
||||||
|
when:
|
||||||
|
- inventory_hostname in groups['etcd']
|
||||||
|
|
||||||
|
- name: Lookup etcd member id
|
||||||
|
shell: "{{ bin_dir }}/etcdctl --no-sync --endpoints={{ etcd_access_addresses }} member list | grep {{ node_ip }} | cut -d: -f1"
|
||||||
|
register: etcd_member_id
|
||||||
|
ignore_errors: true
|
||||||
|
changed_when: false
|
||||||
|
check_mode: no
|
||||||
|
tags:
|
||||||
|
- facts
|
||||||
|
environment:
|
||||||
|
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}.pem"
|
||||||
|
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}-key.pem"
|
||||||
|
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|
||||||
|
delegate_to: "{{ groups['etcd']|first }}"
|
||||||
|
when:
|
||||||
|
- inventory_hostname in groups['etcd']
|
||||||
|
|
||||||
|
- name: Remove etcd member from cluster
|
||||||
|
shell: "{{ bin_dir }}/etcdctl --no-sync --endpoints={{ etcd_access_addresses }} member remove {{ etcd_member_id.stdout }}"
|
||||||
|
register: etcd_member_in_cluster
|
||||||
|
ignore_errors: false
|
||||||
|
retries: 6
|
||||||
|
delay: 5
|
||||||
|
until: etcd_member_in_cluster.rc == 0
|
||||||
|
changed_when: false
|
||||||
|
check_mode: no
|
||||||
|
tags:
|
||||||
|
- facts
|
||||||
|
environment:
|
||||||
|
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}.pem"
|
||||||
|
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ groups['etcd']|first }}-key.pem"
|
||||||
|
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|
||||||
|
delegate_to: "{{ groups['etcd']|first }}"
|
||||||
|
when:
|
||||||
|
- inventory_hostname in groups['etcd']
|
||||||
|
- etcd_member_id.stdout | length > 0
|
Loading…
Reference in a new issue