Homelab/ansible/roles/etcd-witness/tasks/main.yml

42 lines
1.1 KiB
YAML
Raw Normal View History

2025-11-07 09:33:38 +01:00
---
# etcd witness node configuration
# This node participates in etcd quorum but does not run K8s workloads
- name: Check if K3s is already installed
stat:
path: /usr/local/bin/k3s
register: k3s_binary
- name: Get K3s token from first server
set_fact:
k3s_token: >-
{{
lookup('file', k3s_token_file, errors='ignore')
| default('PLACEHOLDER')
}}
2025-11-07 09:33:38 +01:00
- name: Install K3s as server (witness mode)
shell: >
curl -sfL {{ k3s_install_url }} |
INSTALL_K3S_VERSION="{{ k3s_version }}"
sh -s - server
--server https://{{ k3s_server_1_ip }}:6443
--token {{ k3s_token }}
--disable-apiserver
--disable-controller-manager
--disable-scheduler
2025-11-07 09:33:38 +01:00
--node-ip {{ ansible_default_ipv4.address }}
when: not k3s_binary.stat.exists
environment:
INSTALL_K3S_SKIP_START: "false"
- name: Enable and start k3s service
systemd:
name: k3s
state: started
enabled: true
2025-11-07 09:33:38 +01:00
- name: Display witness node information
debug:
msg: "etcd witness node configured at {{ ansible_default_ipv4.address }}"