geerlingguy.ansible-role-ku.../tasks/main.yml

60 lines
1.6 KiB
YAML
Raw Permalink Normal View History

2018-05-09 16:19:11 +02:00
---
- name: Include OS-specific variables.
include_vars: "{{ ansible_os_family }}.yml"
2018-05-09 16:19:11 +02:00
- include_tasks: setup-RedHat.yml
when: ansible_os_family == 'RedHat'
- include_tasks: setup-Debian.yml
when: ansible_os_family == 'Debian'
2018-05-24 21:22:19 +02:00
- name: Ensure dependencies are installed.
2018-05-09 16:19:11 +02:00
package: name=curl state=present
- name: Install Kubernetes packages.
package:
name: "{{ item.name | default(item) }}"
state: "{{ item.state | default('present') }}"
notify: restart kubelet
with_items: "{{ kubernetes_packages }}"
- include_tasks: sysctl-setup.yml
2020-05-20 19:57:47 +02:00
- include_tasks: kubelet-setup.yml # deprecated
when: kubernetes_kubelet_extra_args|length > 0
2018-05-09 16:19:11 +02:00
- name: Ensure kubelet is started and enabled at boot.
service:
name: kubelet
state: started
2018-09-28 05:17:50 +02:00
enabled: true
2018-05-09 16:19:11 +02:00
- name: Check if Kubernetes has already been initialized.
stat:
path: /etc/kubernetes/admin.conf
register: kubernetes_init_stat
# Set up control plane.
- include_tasks: control-plane-setup.yml
when: kubernetes_role == 'control_plane'
2018-05-09 16:19:11 +02:00
# Set up nodes.
- name: Get the kubeadm join command from the Kubernetes control plane.
2018-09-28 05:17:50 +02:00
command: kubeadm token create --print-join-command
changed_when: false
when: kubernetes_role == 'control_plane'
register: kubernetes_join_command_result
- name: Set the kubeadm join command globally.
set_fact:
kubernetes_join_command: >
{{ kubernetes_join_command_result.stdout }}
{{ kubernetes_join_command_extra_opts }}
when: kubernetes_join_command_result.stdout is defined
delegate_to: "{{ item }}"
2018-09-28 05:17:50 +02:00
delegate_facts: true
with_items: "{{ groups['all'] }}"
2018-05-09 21:51:36 +02:00
- include_tasks: node-setup.yml
when: kubernetes_role == 'node'