ensure-kubernetes: install cri-dockerd; fix networking

For ... reasons ... kubernetes deprecated docker as a container
runtime, and requires this cri-dockerd daemon to make docker cri-ish
enough to work.  Install and start it so the docker path keeps
working, although long-term I guess they're saying to move away from
this (from what I read it the "none" driver will also have problems
with cgroupsv2, which makes it's future on Jaunty look interesting).

Honestly I don't really know why the cri-o now needs the
--network-plugin flag.  Without it I get

 X Exiting due to RUNTIME_ENABLE: unknown network plugin:

which isn't described anywhere I can see.  Improvements welcome :)

Change-Id: I8ff34fa116aca14abee7e71f510bc49ffc547524
This commit is contained in:
Ian Wienand 2022-07-27 06:31:14 +10:00
parent ac056cd6da
commit 08c922fd98

View File

@ -17,7 +17,8 @@
# Ubuntu focal doesn't have cri-o-1.15 packages, per distro tasks is # Ubuntu focal doesn't have cri-o-1.15 packages, per distro tasks is
# required to install crio # required to install crio
- name: Install crio - name: Install crio
when: kubernetes_runtime == 'cri-o' # Note this is required even for the docker runtime, as minikube only
# supports cri now. See below for the docker wrapper
include_tasks: "{{ zj_distro_os }}" include_tasks: "{{ zj_distro_os }}"
with_first_found: with_first_found:
- "crio-{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml" - "crio-{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml"
@ -27,7 +28,6 @@
- name: Workaround missing 02-crio.conf - name: Workaround missing 02-crio.conf
# See: https://github.com/kubernetes/minikube/issues/13816 # See: https://github.com/kubernetes/minikube/issues/13816
when: kubernetes_runtime == 'cri-o'
block: block:
- name: Add misisng crio.conf.d folder - name: Add misisng crio.conf.d folder
file: file:
@ -84,6 +84,41 @@
extra_args: "--extra-config=kubelet.resolv-conf={{ ansible_user_dir }}/.minikube/k8s_resolv.conf" extra_args: "--extra-config=kubelet.resolv-conf={{ ansible_user_dir }}/.minikube/k8s_resolv.conf"
when: minikube_dns_resolvers|length>0 when: minikube_dns_resolvers|length>0
# See https://github.com/kubernetes/minikube/issues/14410
- name: Setup cri-dockerd
when: kubernetes_runtime == 'docker'
become: yes
block:
- name: Check for pre-existing cri-docker service
stat:
path: '/etc/system/cri-docker.service'
register: _cri_docker
- name: Install cri-docker
when: not _cri_docker.stat.exists
shell: |
set -x
VER=$(curl -s https://api.github.com/repos/Mirantis/cri-dockerd/releases/latest|grep tag_name | cut -d '"' -f 4|sed 's/v//g')
DL=$(mktemp -d)
pushd ${DL}
wget https://github.com/Mirantis/cri-dockerd/releases/download/v${VER}/cri-dockerd-${VER}.amd64.tgz
tar xvf cri-dockerd-${VER}.amd64.tgz
mv cri-dockerd/cri-dockerd /usr/local/bin
wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.service
wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/master/packaging/systemd/cri-docker.socket
sudo mv cri-docker.socket cri-docker.service /etc/systemd/system/
sed -i -e 's,/usr/bin/cri-dockerd,/usr/local/bin/cri-dockerd,' /etc/systemd/system/cri-docker.service
popd
rm -rf ${DL}
systemctl daemon-reload
args:
executable: '/bin/bash'
- name: Ensure cri-dockerd running
service:
name: cri-docker
state: started
- name: Start Minikube - name: Start Minikube
become: yes become: yes
command: >- command: >-
@ -95,6 +130,7 @@
{% for _addon in ensure_kubernetes_minikube_addons %} {% for _addon in ensure_kubernetes_minikube_addons %}
--addons={{ _addon }} --addons={{ _addon }}
{% endfor %} {% endfor %}
{{ '--network-plugin=cni' if kubernetes_runtime == 'cri-o' }}
environment: environment:
MINIKUBE_WANTUPDATENOTIFICATION: false MINIKUBE_WANTUPDATENOTIFICATION: false
MINIKUBE_WANTREPORTERRORPROMPT: false MINIKUBE_WANTREPORTERRORPROMPT: false