diff --git a/playbooks/boilerplate.yml b/playbooks/boilerplate.yml new file mode 100644 index 00000000000..4e37da2fa83 --- /dev/null +++ b/playbooks/boilerplate.yml @@ -0,0 +1,14 @@ +--- +- name: Check ansible version + import_playbook: ansible_version.yml + +- name: Ensure compatibility with old groups + import_playbook: legacy_groups.yml + +- name: Install bastion ssh config + hosts: bastion[0] + gather_facts: False + environment: "{{ proxy_disable_env }}" + roles: + - { role: kubespray-defaults } + - { role: bastion-ssh-config, tags: ["localhost", "bastion"] } diff --git a/playbooks/cluster.yml b/playbooks/cluster.yml index 85a483a3cf8..a6fd770b957 100644 --- a/playbooks/cluster.yml +++ b/playbooks/cluster.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - { role: bastion-ssh-config, tags: ["localhost", "bastion"] } +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Gather facts import_playbook: facts.yml @@ -28,35 +17,7 @@ - { role: download, tags: download, when: "not skip_downloads" } - name: Install etcd - hosts: etcd:kube_control_plane - gather_facts: False - any_errors_fatal: "{{ any_errors_fatal | default(true) }}" - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - role: etcd - tags: etcd - vars: - etcd_cluster_setup: true - etcd_events_cluster_setup: "{{ etcd_events_cluster_enabled }}" - when: etcd_deployment_type != "kubeadm" - -- name: Install etcd certs on nodes if required - hosts: k8s_cluster - gather_facts: False - any_errors_fatal: "{{ any_errors_fatal | default(true) }}" - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - role: etcd - tags: etcd - vars: - etcd_cluster_setup: false - etcd_events_cluster_setup: false - when: - - etcd_deployment_type != "kubeadm" - - kube_network_plugin in ["calico", "flannel", "canal", "cilium"] or cilium_deploy_additionally | default(false) | bool - - kube_network_plugin != "calico" or calico_datastore == "etcd" + import_playbook: install_etcd.yml - name: Install Kubernetes nodes hosts: k8s_cluster diff --git a/playbooks/install_etcd.yml b/playbooks/install_etcd.yml new file mode 100644 index 00000000000..9bd13dfcd6e --- /dev/null +++ b/playbooks/install_etcd.yml @@ -0,0 +1,31 @@ +--- +- name: Install etcd + hosts: etcd:kube_control_plane + gather_facts: False + any_errors_fatal: "{{ any_errors_fatal | default(true) }}" + environment: "{{ proxy_disable_env }}" + roles: + - { role: kubespray-defaults } + - role: etcd + tags: etcd + vars: + etcd_cluster_setup: true + etcd_events_cluster_setup: "{{ etcd_events_cluster_enabled }}" + when: etcd_deployment_type != "kubeadm" + +- name: Install etcd certs on nodes if required + hosts: k8s_cluster + gather_facts: False + any_errors_fatal: "{{ any_errors_fatal | default(true) }}" + environment: "{{ proxy_disable_env }}" + roles: + - { role: kubespray-defaults } + - role: etcd + tags: etcd + vars: + etcd_cluster_setup: false + etcd_events_cluster_setup: false + when: + - etcd_deployment_type != "kubeadm" + - kube_network_plugin in ["calico", "flannel", "canal", "cilium"] or cilium_deploy_additionally | default(false) | bool + - kube_network_plugin != "calico" or calico_datastore == "etcd" diff --git a/playbooks/recover_control_plane.yml b/playbooks/recover_control_plane.yml index d2bb5742745..35ed2c27672 100644 --- a/playbooks/recover_control_plane.yml +++ b/playbooks/recover_control_plane.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults} - - { role: bastion-ssh-config, tags: ["localhost", "bastion"]} +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Recover etcd hosts: etcd[0] diff --git a/playbooks/remove_node.yml b/playbooks/remove_node.yml index 63df859385a..e01338965e1 100644 --- a/playbooks/remove_node.yml +++ b/playbooks/remove_node.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - { role: bastion-ssh-config, tags: ["localhost", "bastion"] } +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Confirm node removal hosts: "{{ node | default('etcd:k8s_cluster:calico_rr') }}" diff --git a/playbooks/reset.yml b/playbooks/reset.yml index 0b4312fbd7a..5742bd844e4 100644 --- a/playbooks/reset.yml +++ b/playbooks/reset.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults} - - { role: bastion-ssh-config, tags: ["localhost", "bastion"]} +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Gather facts import_playbook: facts.yml diff --git a/playbooks/scale.yml b/playbooks/scale.yml index aaa1bf5841b..b8f87f484e8 100644 --- a/playbooks/scale.yml +++ b/playbooks/scale.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - { role: bastion-ssh-config, tags: ["localhost", "bastion"] } +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Gather facts import_playbook: facts.yml diff --git a/playbooks/upgrade_cluster.yml b/playbooks/upgrade_cluster.yml index 3e2125c83d2..a79cf0aa763 100644 --- a/playbooks/upgrade_cluster.yml +++ b/playbooks/upgrade_cluster.yml @@ -1,17 +1,6 @@ --- -- name: Check ansible version - import_playbook: ansible_version.yml - -- name: Ensure compatibility with old groups - import_playbook: legacy_groups.yml - -- name: Install bastion ssh config - hosts: bastion[0] - gather_facts: False - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - { role: bastion-ssh-config, tags: ["localhost", "bastion"] } +- name: Common tasks for every playbooks + import_playbook: boilerplate.yml - name: Gather facts import_playbook: facts.yml @@ -47,35 +36,7 @@ - { role: container-engine, tags: "container-engine", when: deploy_container_engine } - name: Install etcd - hosts: etcd:kube_control_plane - gather_facts: False - any_errors_fatal: "{{ any_errors_fatal | default(true) }}" - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - role: etcd - tags: etcd - vars: - etcd_cluster_setup: true - etcd_events_cluster_setup: "{{ etcd_events_cluster_enabled }}" - when: etcd_deployment_type != "kubeadm" - -- name: Install etcd certs on nodes if required - hosts: k8s_cluster - gather_facts: False - any_errors_fatal: "{{ any_errors_fatal | default(true) }}" - environment: "{{ proxy_disable_env }}" - roles: - - { role: kubespray-defaults } - - role: etcd - tags: etcd - vars: - etcd_cluster_setup: false - etcd_events_cluster_setup: false - when: - - etcd_deployment_type != "kubeadm" - - kube_network_plugin in ["calico", "flannel", "canal", "cilium"] or cilium_deploy_additionally | default(false) | bool - - kube_network_plugin != "calico" or calico_datastore == "etcd" + import_playbook: install_etcd.yml - name: Handle upgrades to master components first to maintain backwards compat. gather_facts: False