2026-02-28 20:24:55 +00:00
|
|
|
---
|
2026-02-28 23:16:39 +00:00
|
|
|
- name: Check if k3s service exists
|
2026-02-28 20:24:55 +00:00
|
|
|
stat:
|
2026-02-28 23:16:39 +00:00
|
|
|
path: /etc/systemd/system/k3s.service
|
|
|
|
|
register: k3s_service
|
|
|
|
|
|
|
|
|
|
- name: Check if k3s is part of cluster
|
|
|
|
|
stat:
|
|
|
|
|
path: /var/lib/rancher/k3s/server/node-token
|
|
|
|
|
register: k3s_cluster_member
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Download k3s install script
|
|
|
|
|
get_url:
|
|
|
|
|
url: https://get.k3s.io
|
|
|
|
|
dest: /tmp/install-k3s.sh
|
|
|
|
|
mode: "0755"
|
2026-02-28 23:16:39 +00:00
|
|
|
when: not k3s_service.stat.exists
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Install k3s server (primary)
|
|
|
|
|
environment:
|
|
|
|
|
INSTALL_K3S_VERSION: "{{ k3s_version if k3s_version != 'latest' else '' }}"
|
|
|
|
|
K3S_TOKEN: "{{ k3s_token }}"
|
|
|
|
|
command: /tmp/install-k3s.sh server --cluster-init
|
|
|
|
|
when:
|
2026-02-28 23:16:39 +00:00
|
|
|
- not k3s_service.stat.exists
|
2026-02-28 20:24:55 +00:00
|
|
|
- k3s_primary | default(false)
|
|
|
|
|
|
|
|
|
|
- name: Install k3s server (secondary)
|
|
|
|
|
environment:
|
|
|
|
|
INSTALL_K3S_VERSION: "{{ k3s_version if k3s_version != 'latest' else '' }}"
|
|
|
|
|
K3S_TOKEN: "{{ k3s_token }}"
|
|
|
|
|
command: /tmp/install-k3s.sh server --server https://{{ k3s_primary_ip }}:6443
|
|
|
|
|
when:
|
2026-02-28 23:16:39 +00:00
|
|
|
- not k3s_service.stat.exists
|
2026-02-28 20:24:55 +00:00
|
|
|
- not (k3s_primary | default(false))
|
|
|
|
|
|
|
|
|
|
- name: Wait for k3s to be ready
|
|
|
|
|
command: kubectl get nodes
|
|
|
|
|
register: k3s_ready
|
|
|
|
|
until: k3s_ready.rc == 0
|
|
|
|
|
retries: 30
|
|
|
|
|
delay: 10
|
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
|
|
- name: Copy kubeconfig to default location for root
|
|
|
|
|
file:
|
|
|
|
|
src: /etc/rancher/k3s/k3s.yaml
|
|
|
|
|
dest: /root/.kube/config
|
|
|
|
|
state: link
|
|
|
|
|
force: true
|
|
|
|
|
|
|
|
|
|
- name: Ensure .kube directory exists for ansible user
|
|
|
|
|
file:
|
|
|
|
|
path: "/home/{{ ansible_user }}/.kube"
|
|
|
|
|
state: directory
|
|
|
|
|
mode: "0755"
|
|
|
|
|
when: ansible_user != 'root'
|