ac2135e450
* Fix recover-control-plane to work with etcd 3.3.x and add CI * Set default values for testcase * Add actual test jobs * Attempt to satisty gitlab ci linter * Fix ansible targets * Set etcd_member_name as stated in the docs... * Recovering from 0 masters is not supported yet * Add other master to broken_kube-master group as well * Increase number of retries to see if etcd needs more time to heal * Make number of retries for ETCD loops configurable, increase it for recovery CI and document it
38 lines
1.6 KiB
YAML
38 lines
1.6 KiB
YAML
---
|
|
- name: Join Member | Add member to etcd cluster
|
|
shell: "{{ bin_dir }}/etcdctl --endpoints={{ etcd_access_addresses }} member add {{ etcd_member_name }} {{ etcd_peer_url }}"
|
|
register: member_add_result
|
|
until: member_add_result.rc == 0
|
|
retries: "{{ etcd_retries }}"
|
|
delay: "{{ retry_stagger | random + 3 }}"
|
|
when: target_node == inventory_hostname
|
|
environment:
|
|
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ inventory_hostname }}.pem"
|
|
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ inventory_hostname }}-key.pem"
|
|
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|
|
|
|
- include_tasks: refresh_config.yml
|
|
vars:
|
|
etcd_peer_addresses: >-
|
|
{% for host in groups['etcd'] -%}
|
|
{%- if hostvars[host]['etcd_member_in_cluster'].rc == 0 -%}
|
|
{{ "etcd"+loop.index|string }}=https://{{ hostvars[host].access_ip | default(hostvars[host].ip | default(fallback_ips[host])) }}:2380,
|
|
{%- endif -%}
|
|
{%- if loop.last -%}
|
|
{{ etcd_member_name }}={{ etcd_peer_url }}
|
|
{%- endif -%}
|
|
{%- endfor -%}
|
|
when: target_node == inventory_hostname
|
|
|
|
- name: Join Member | Ensure member is in etcd cluster
|
|
shell: "{{ bin_dir }}/etcdctl --no-sync --endpoints={{ etcd_access_addresses }} member list | grep -q {{ etcd_access_address }}"
|
|
register: etcd_member_in_cluster
|
|
changed_when: false
|
|
check_mode: no
|
|
tags:
|
|
- facts
|
|
when: target_node == inventory_hostname
|
|
environment:
|
|
ETCDCTL_CERT_FILE: "{{ etcd_cert_dir }}/admin-{{ inventory_hostname }}.pem"
|
|
ETCDCTL_KEY_FILE: "{{ etcd_cert_dir }}/admin-{{ inventory_hostname }}-key.pem"
|
|
ETCDCTL_CA_FILE: "{{ etcd_cert_dir }}/ca.pem"
|