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
|
|
|
|
|
|
2026-03-01 01:25:20 +00:00
|
|
|
- name: Check k3s service state
|
|
|
|
|
command: systemctl is-active k3s
|
|
|
|
|
register: k3s_service_state
|
|
|
|
|
changed_when: false
|
|
|
|
|
failed_when: false
|
|
|
|
|
when: k3s_service.stat.exists
|
|
|
|
|
|
|
|
|
|
- name: Determine whether k3s install is needed
|
|
|
|
|
set_fact:
|
|
|
|
|
k3s_install_needed: "{{ (not k3s_service.stat.exists) or ((k3s_service_state.stdout | default('')) != 'active') }}"
|
|
|
|
|
|
|
|
|
|
- name: Wait for primary API on 6443 (secondary only)
|
|
|
|
|
wait_for:
|
|
|
|
|
host: "{{ k3s_primary_ip }}"
|
|
|
|
|
port: 6443
|
|
|
|
|
state: started
|
|
|
|
|
timeout: 120
|
|
|
|
|
when:
|
|
|
|
|
- not (k3s_primary | default(false))
|
|
|
|
|
|
|
|
|
|
- name: Check if uninstall script exists
|
2026-02-28 23:16:39 +00:00
|
|
|
stat:
|
2026-03-01 01:25:20 +00:00
|
|
|
path: /usr/local/bin/k3s-uninstall.sh
|
|
|
|
|
register: k3s_uninstall_script
|
2026-03-21 16:10:17 +00:00
|
|
|
when: k3s_install_needed
|
2026-03-01 01:25:20 +00:00
|
|
|
|
2026-03-21 16:10:17 +00:00
|
|
|
- name: Reset broken k3s install before reinstall
|
2026-03-01 01:25:20 +00:00
|
|
|
command: /usr/local/bin/k3s-uninstall.sh
|
|
|
|
|
when:
|
|
|
|
|
- k3s_install_needed
|
|
|
|
|
- k3s_uninstall_script.stat.exists
|
|
|
|
|
|
2026-03-21 16:10:17 +00:00
|
|
|
- name: Remove stale k3s data
|
2026-03-01 01:25:20 +00:00
|
|
|
file:
|
|
|
|
|
path: "{{ item }}"
|
|
|
|
|
state: absent
|
|
|
|
|
loop:
|
|
|
|
|
- /etc/rancher/k3s
|
|
|
|
|
- /var/lib/rancher/k3s
|
2026-03-21 16:10:17 +00:00
|
|
|
when: k3s_install_needed
|
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-03-01 01:25:20 +00:00
|
|
|
when: k3s_install_needed
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Install k3s server (primary)
|
2026-03-21 16:10:17 +00:00
|
|
|
environment:
|
|
|
|
|
INSTALL_K3S_VERSION: "{{ k3s_version if k3s_version != 'latest' else '' }}"
|
|
|
|
|
K3S_TOKEN: "{{ k3s_token }}"
|
|
|
|
|
command: >-
|
|
|
|
|
/tmp/install-k3s.sh server
|
|
|
|
|
--cluster-init
|
|
|
|
|
--advertise-address={{ k3s_primary_ip }}
|
|
|
|
|
--node-ip={{ k3s_node_ip }}
|
|
|
|
|
--tls-san={{ k3s_primary_ip }}
|
|
|
|
|
--tls-san={{ k3s_primary_public_ip }}
|
|
|
|
|
{% if k3s_disable_embedded_ccm | bool %}--disable-cloud-controller{% endif %}
|
|
|
|
|
{% if k3s_disable_servicelb | bool %}--disable=servicelb{% endif %}
|
|
|
|
|
{% if k3s_kubelet_cloud_provider_external | bool %}--kubelet-arg=cloud-provider=external{% endif %}
|
|
|
|
|
when:
|
|
|
|
|
- k3s_install_needed
|
|
|
|
|
- k3s_primary | default(false)
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Install k3s server (secondary)
|
2026-03-01 02:05:07 +00:00
|
|
|
when:
|
2026-03-01 01:25:20 +00:00
|
|
|
- k3s_install_needed
|
2026-02-28 20:24:55 +00:00
|
|
|
- not (k3s_primary | default(false))
|
2026-03-01 02:05:07 +00:00
|
|
|
block:
|
|
|
|
|
- name: Run secondary k3s install
|
|
|
|
|
environment:
|
|
|
|
|
INSTALL_K3S_VERSION: "{{ k3s_version if k3s_version != 'latest' else '' }}"
|
|
|
|
|
K3S_TOKEN: "{{ k3s_token }}"
|
2026-03-17 01:21:23 +00:00
|
|
|
command: >-
|
|
|
|
|
/tmp/install-k3s.sh server
|
|
|
|
|
--server https://{{ k3s_primary_ip }}:6443
|
|
|
|
|
--advertise-address={{ k3s_node_ip }}
|
|
|
|
|
--node-ip={{ k3s_node_ip }}
|
2026-03-21 16:10:17 +00:00
|
|
|
{% if k3s_disable_embedded_ccm | bool %}--disable-cloud-controller{% endif %}
|
|
|
|
|
{% if k3s_disable_servicelb | bool %}--disable=servicelb{% endif %}
|
|
|
|
|
{% if k3s_kubelet_cloud_provider_external | bool %}--kubelet-arg=cloud-provider=external{% endif %}
|
2026-03-01 02:05:07 +00:00
|
|
|
register: secondary_install
|
|
|
|
|
|
|
|
|
|
rescue:
|
|
|
|
|
- name: Show k3s service status after failed secondary install
|
|
|
|
|
command: systemctl status k3s --no-pager
|
|
|
|
|
register: k3s_status_after_install
|
|
|
|
|
changed_when: false
|
|
|
|
|
failed_when: false
|
|
|
|
|
|
|
|
|
|
- name: Show recent k3s logs after failed secondary install
|
|
|
|
|
command: journalctl -u k3s -n 120 --no-pager
|
|
|
|
|
register: k3s_journal_after_install
|
|
|
|
|
changed_when: false
|
|
|
|
|
failed_when: false
|
|
|
|
|
|
|
|
|
|
- name: Fail with secondary install diagnostics
|
|
|
|
|
fail:
|
|
|
|
|
msg: |
|
|
|
|
|
Secondary k3s install failed on {{ inventory_hostname }}.
|
|
|
|
|
Install stdout:
|
|
|
|
|
{{ secondary_install.stdout | default('n/a') }}
|
|
|
|
|
|
|
|
|
|
Install stderr:
|
|
|
|
|
{{ secondary_install.stderr | default('n/a') }}
|
|
|
|
|
|
|
|
|
|
Service status:
|
|
|
|
|
{{ k3s_status_after_install.stdout | default('n/a') }}
|
|
|
|
|
|
|
|
|
|
Recent logs:
|
|
|
|
|
{{ k3s_journal_after_install.stdout | default('n/a') }}
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Wait for k3s to be ready
|
2026-03-01 00:42:55 +00:00
|
|
|
command: "{{ (k3s_primary | default(false)) | ternary('kubectl get nodes', 'systemctl is-active k3s') }}"
|
2026-02-28 20:24:55 +00:00
|
|
|
register: k3s_ready
|
|
|
|
|
until: k3s_ready.rc == 0
|
2026-03-01 00:59:17 +00:00
|
|
|
retries: 120
|
2026-02-28 20:24:55 +00:00
|
|
|
delay: 10
|
|
|
|
|
changed_when: false
|
|
|
|
|
|
2026-03-01 00:59:17 +00:00
|
|
|
- name: Show k3s service status on failure
|
|
|
|
|
command: systemctl status k3s --no-pager
|
|
|
|
|
register: k3s_status
|
|
|
|
|
changed_when: false
|
|
|
|
|
failed_when: false
|
|
|
|
|
when: k3s_ready is failed
|
|
|
|
|
|
|
|
|
|
- name: Show recent k3s logs on failure
|
|
|
|
|
command: journalctl -u k3s -n 80 --no-pager
|
|
|
|
|
register: k3s_journal
|
|
|
|
|
changed_when: false
|
|
|
|
|
failed_when: false
|
|
|
|
|
when: k3s_ready is failed
|
|
|
|
|
|
|
|
|
|
- name: Fail with k3s diagnostics
|
|
|
|
|
fail:
|
|
|
|
|
msg: |
|
|
|
|
|
k3s failed to become ready on {{ inventory_hostname }}.
|
|
|
|
|
Service status:
|
|
|
|
|
{{ k3s_status.stdout | default('n/a') }}
|
|
|
|
|
|
|
|
|
|
Recent logs:
|
|
|
|
|
{{ k3s_journal.stdout | default('n/a') }}
|
|
|
|
|
when: k3s_ready is failed
|
|
|
|
|
|
2026-03-01 03:02:37 +00:00
|
|
|
- name: Copy kubeconfig to default location for root
|
|
|
|
|
file:
|
|
|
|
|
path: /root/.kube
|
|
|
|
|
state: directory
|
|
|
|
|
mode: "0700"
|
|
|
|
|
when: k3s_primary | default(false)
|
|
|
|
|
|
2026-02-28 20:24:55 +00:00
|
|
|
- name: Copy kubeconfig to default location for root
|
|
|
|
|
file:
|
|
|
|
|
src: /etc/rancher/k3s/k3s.yaml
|
|
|
|
|
dest: /root/.kube/config
|
|
|
|
|
state: link
|
|
|
|
|
force: true
|
2026-03-01 03:02:37 +00:00
|
|
|
when: k3s_primary | default(false)
|
2026-02-28 20:24:55 +00:00
|
|
|
|
|
|
|
|
- name: Ensure .kube directory exists for ansible user
|
|
|
|
|
file:
|
|
|
|
|
path: "/home/{{ ansible_user }}/.kube"
|
|
|
|
|
state: directory
|
|
|
|
|
mode: "0755"
|
2026-03-01 03:02:37 +00:00
|
|
|
when:
|
|
|
|
|
- ansible_user != 'root'
|
|
|
|
|
- k3s_primary | default(false)
|