Revert "Revert cri-dockerd changes"

This reverts commit c4a666991207f9434a819da9bac8b3603ad3d66e.

The change was originally reverted because it broke testing on Jammy.
Jammy broke because it was attempting to install cri-o using the Bionic
method via a PPA. This is no longer valid for newer Ubuntu, and Focal
uses a different process too. We update the cri-o installation for Jammy
to match Focal and make this method the default so that new Ubuntu
releases default to modern installation methods. Bionic continues to
install from a PPA.

Additionally we bump the cri-o version from 1.15 to 1.24 to get a
version that has packages for both Focal and Jammy. This new version
requires we also install cri-o-runc separately as they don't seem to
have proper package dependencies in place between these two packages.
The crio systemd service fails to start without cri-o-runc installed.

Change-Id: Ic29576e26be094744cc1b169a3c8f0bca814f089
This commit is contained in:
James E. Blair 2022-07-28 08:39:55 -07:00 committed by Clark Boylan
parent 9101dd322c
commit 300ee42863
4 changed files with 92 additions and 55 deletions

View File

@ -0,0 +1,42 @@
- name: Add project atomic PPA
apt_repository:
repo: ppa:projectatomic/ppa
become: true
- name: Install packages
package:
name:
- cri-o-1.15
- containernetworking-plugins
- podman
- cri-tools
state: present
become: true
- name: Fix conmon symlink
file:
src: /usr/bin/conmon
dest: /usr/libexec/crio/conmon
owner: root
group: root
state: link
become: true
- name: Fix missing registries.conf
# See: https://github.com/containers/podman.io/issues/127
copy:
content: |
[registries.search]
registries = []
[registries.insecure]
registries = []
[registries.block]
registries = []
dest: /etc/containers/registries.conf
mode: 0644
become: true
- name: Set crio cgroup driver
ini_file:
path: /etc/crio/crio.conf
section: crio.runtime
option: cgroup_manager
value: '"cgroupfs"'
mode: 0644
become: true

View File

@ -1,27 +0,0 @@
- name: Add all repositories
include_role:
name: ensure-package-repositories
vars:
repositories_keys:
- url: "https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_{{ ansible_distribution_version }}/Release.key"
- url: "https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/1.16/xUbuntu_{{ ansible_distribution_version }}/Release.key"
repositories_list:
- repo: "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_{{ ansible_distribution_version }}/ /"
- repo: "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/1.16/xUbuntu_{{ ansible_distribution_version }}/ /"
- name: Install packages
package:
name:
- cri-o-1.16
- containernetworking-plugins
- podman
- cri-tools
state: present
become: true
- name: Set crio cgroup driver
ini_file:
path: /etc/crio/crio.conf
section: crio.runtime
option: cgroup_manager
value: '"cgroupfs"'
mode: 0644
become: true

View File

@ -1,37 +1,23 @@
- name: Add project atomic PPA - name: Add all repositories
apt_repository: include_role:
repo: ppa:projectatomic/ppa name: ensure-package-repositories
become: true vars:
repositories_keys:
- url: "https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_{{ ansible_distribution_version }}/Release.key"
- url: "https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/1.24/xUbuntu_{{ ansible_distribution_version }}/Release.key"
repositories_list:
- repo: "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable/xUbuntu_{{ ansible_distribution_version }}/ /"
- repo: "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/stable:/cri-o:/1.24/xUbuntu_{{ ansible_distribution_version }}/ /"
- name: Install packages - name: Install packages
package: package:
name: name:
- cri-o-1.15 - cri-o
- cri-o-runc
- containernetworking-plugins - containernetworking-plugins
- podman - podman
- cri-tools - cri-tools
state: present state: present
become: true become: true
- name: Fix conmon symlink
file:
src: /usr/bin/conmon
dest: /usr/libexec/crio/conmon
owner: root
group: root
state: link
become: true
- name: Fix missing registries.conf
# See: https://github.com/containers/podman.io/issues/127
copy:
content: |
[registries.search]
registries = []
[registries.insecure]
registries = []
[registries.block]
registries = []
dest: /etc/containers/registries.conf
mode: 0644
become: true
- name: Set crio cgroup driver - name: Set crio cgroup driver
ini_file: ini_file:
path: /etc/crio/crio.conf path: /etc/crio/crio.conf

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/v${VER}/packaging/systemd/cri-docker.service
wget https://raw.githubusercontent.com/Mirantis/cri-dockerd/v${VER}/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