|
| 1 | +--- |
| 2 | + |
| 3 | +- name: Check for existing k3s installation |
| 4 | + stat: |
| 5 | + path: /var/lib/rancher/k3s |
| 6 | + register: stat_result |
| 7 | + |
| 8 | +- name: Perform air-gapped installation of k3s |
| 9 | + # Using air-gapped install so containers are pre-installed to avoid rate-limiting from registries on cluster startup |
| 10 | + when: not stat_result.stat.exists |
| 11 | + block: |
| 12 | + |
| 13 | + - name: Download k3s binary |
| 14 | + ansible.builtin.get_url: |
| 15 | + url: "https://github.com/k3s-io/k3s/releases/download/{{ k3s_version | urlencode }}/k3s" |
| 16 | + dest: /usr/bin/k3s |
| 17 | + owner: root |
| 18 | + group: root |
| 19 | + mode: "0755" |
| 20 | + |
| 21 | + - name: Install k3s SELinux policy package |
| 22 | + yum: |
| 23 | + name: "https://github.com/k3s-io/k3s-selinux/releases/download/{{ k3s_selinux_release }}/k3s-selinux-{{ k3s_selinux_rpm_version }}.el{{ ansible_distribution_major_version }}.noarch.rpm" |
| 24 | + disable_gpg_check: true |
| 25 | + |
| 26 | + - name: Create image directory |
| 27 | + ansible.builtin.file: |
| 28 | + path: "/var/lib/rancher/k3s/agent/images" |
| 29 | + state: directory |
| 30 | + |
| 31 | + - name: Install k3s' internal images |
| 32 | + ansible.builtin.get_url: |
| 33 | + url: "https://github.com/k3s-io/k3s/releases/download/{{ k3s_version | urlencode }}/k3s-airgap-images-amd64.tar.zst" |
| 34 | + dest: /var/lib/rancher/k3s/agent/images/k3s-airgap-images-amd64.tar.zst |
| 35 | + |
| 36 | + - name: Download k3s install script |
| 37 | + ansible.builtin.get_url: |
| 38 | + url: https://get.k3s.io/ |
| 39 | + timeout: 120 |
| 40 | + dest: /usr/bin/k3s-install.sh |
| 41 | + owner: root |
| 42 | + group: root |
| 43 | + mode: "0755" |
| 44 | + |
| 45 | + - name: Install k3s |
| 46 | + ansible.builtin.shell: |
| 47 | + cmd: /usr/bin/k3s-install.sh |
| 48 | + environment: |
| 49 | + INSTALL_K3S_VERSION: "{{ k3s_version }}" |
| 50 | + INSTALL_K3S_EXEC: "{{ item }}" |
| 51 | + INSTALL_K3S_SKIP_START: "true" |
| 52 | + INSTALL_K3S_SKIP_ENABLE: "true" |
| 53 | + INSTALL_K3S_BIN_DIR: "/usr/bin" |
| 54 | + INSTALL_K3S_SKIP_DOWNLOAD: "true" |
| 55 | + changed_when: true |
| 56 | + loop: |
| 57 | + - server --disable=traefik |
| 58 | + - agent |
| 59 | + |
| 60 | +- name: Install helm |
| 61 | + unarchive: |
| 62 | + src: "https://get.helm.sh/helm-{{ k3s_helm_version }}-linux-amd64.tar.gz" |
| 63 | + dest: /usr/bin |
| 64 | + extra_opts: "--strip-components=1" |
| 65 | + owner: root |
| 66 | + group: root |
| 67 | + mode: 0755 |
| 68 | + remote_src: true |
| 69 | + |
| 70 | +- name: Add k3s kubeconfig as environment variable |
| 71 | + ansible.builtin.lineinfile: |
| 72 | + path: /etc/environment |
| 73 | + line: "KUBECONFIG=/etc/rancher/k3s/k3s.yaml" |
| 74 | + |
| 75 | +- name: Install ansible-init playbook for k3s agent or server activation |
| 76 | + copy: |
| 77 | + src: start_k3s.yml |
| 78 | + dest: /etc/ansible-init/playbooks/0-start-k3s.yml |
0 commit comments